在很多应用领域中,比如在DNA序列中寻找特殊的模式,都要用到模式匹配,所以模式匹配是一门重要的学科。由于模式匹配问题的求解效率的重要性,对模式匹配加密算法的研究很早就受到重视,模式匹配分为单模式匹配和多模式匹配,那么我们今天就先来介绍几款常用单模式匹配加密算法。
常用单模式匹配加密算法
1、BF加密算法
BF加密算法是最简单的算法,是从左到右进行匹配的。
(1)BF加密算法的思想
首先将T1与P1,进行比较,若不同,就将T2与P1进行比较,……,直到T的某一个字符Ti和P1相同,再将它们之后的字符进行比较,若也相同,则如此继续往下比较,当T的某一个字符Ti与P的字符Pj不同时,则T返回到本趟开始字符的下一个字符,即Ti-j+2,P返回到P1,继续开始下一趟的比较,重复上述过程。若P中的字符全部比较完,则说明本趟匹配成功,本趟的起始位置是i-j=1或i-t[0],否则,匹配失败。
BF加密算法是较简单、直观的加密算法,但它可能产生不必要的回溯,所以减慢了模式匹配的速度,效率很低,时间复杂度为T(n)=O(m*n)。
2、KMP加密算法
由于BF加密算法的缺点。KMP加密算法产生了。KMP加密算法是由BF改进后不产生回溯的一种算法。
(1)KMP加密算法的思想
每当匹配过程中出现字符串比较不等时,不需回溯i指针,而是利用已经得到的”部分匹配”结果将模式向右”滑动”尽可能远的一段距离后,继续进行比较。
KMP加密算法将模式串向右滑动可以提高匹配算法的效率,但相对比较复杂,时间复杂度为T(n)=O(m+n),空间复杂度为S(n)=O(m)。
3、BM加密算法
受KMP加密算法的启发,提出了一种新的字符串快速匹配算法一BM加密算法。BM加密算法在实际的模式匹配中,跳过了很多无用的字符,这种跳跃式的比较方式,使BM加密算法获得了极高的效率,特别是在大字符集上进行字符串的模式匹配时。在实际的应用中,BM加密算法比KMP加密算法更有效率。
BM加密算法从另外一个角度出发,提出一种比较新颖的方法来求解模式匹配问题。
(1)BM加密算法的思想
从右向左的把模式同文本做比较。开始时仍是P的最左边与T的最左边对齐,当某趟比较中出现不匹配时,BM加密算法采用两条启发性规则计算模式串右移的距离,即坏字符启发规则和好后缀启发规则;当与最右的模式符号做比较的文本符号在模式中根本就没有出现,则模式可以在这个文本符号之后移位m个位置。
作如下定义:
串中出现的字符,
字符集:C={C|C在正文中出现}
正文串T:T1T2…一Ti…Tim-j…Tn
模式串P:T1…Tj…T
坏字符规则:
在BM加密算法从右向左扫描的过程中,若发现某个字符x不匹配,则按如下两种情况讨论:
1) 如果字符x在模式P中没有出现,那么从字符x开始的m个文本显然不可能与P匹配成功,直接全部跳过该区域即可。
2)如果x在模式P中出现,则以该字符进行对齐。
用数学公式表示,设Skip(x)为P右移的距离,m为模式串P的长度,max(x)为字符x在P中最右位置。
好后缀规则:
若发现某个字符不匹配的同时,已有部分字符匹配成功,则按如下两种情况讨论:
1)如果在P中位置t处已匹配部分P'在P中的某位置t'也出现,且位置t'的前一个字符与位置t的前一个字符不相同,则将P右移使t'对应t方才的所在的位置。
2)如果在P中任何位置已匹配部分P'都没有再出现,则找到与P'的后缀P''相同的P的最长前缀x,向右移动P,使x对应方才P''后缀所在的位置。
用数学公式表示,设Shift(j)为P右移的距离,m为模式串P的长度,j 为当前所匹配的字符位置,s为t'与t的距离(以上情况1)或者x与P''的距离(以上情况2)。
(2)BM加密算法流程图
在匹配过程中,取dist1和dist2中的最大者,其流程图如图所示。
其预处理阶段时间复杂度为O(m+s),空间复杂度为O(s)。搜索阶段时间复杂度为O(m*n),最坏情况下要比_较进行3n次比较,最好情况下时间复杂度为O(n/m)。
随着网络的发展,模式匹配加密算法的应用越来越广,因而提高模式匹配加密算法的效率也是当前研究的热点。
小知识之模式匹配
助您决策!2025年受欢迎的内网安全软件排行
随着数字化进程的加速,内网安全已经成为企业不可忽视的重要环节。选择一款高效、可靠的内网安全软件,对于保障企业信息安全、提升运营效率至关重要。今天,我们就来聊聊几款在2025年备受推崇的内网安全软件,看看它们的技术特点和创新之处。一、域智盾:智能监控的佼佼者域智盾以其强大的实时监控能力脱颖而出。它能够同时追踪多台终端操作...
助力企业高效运营的电脑管控工具
企业想要在激烈的市场竞争中站稳脚跟,高效运营可是必不可少的关键。一说到高效运营,就不得不提那些在后台默默发力的电脑管控工具了。这些工具就好比企业的超级贴心助手,不仅让管理变得轻松许多,还能在不知不觉中提升工作效率,保证业务顺顺当当开展。今天,咱们就来聊聊这些神奇小帮手的技术亮点,看看它们是怎么用创新的法子助力企业向前冲...
掌握监控新趋势:局域网远程监控系统优势探秘
如今科技发展那叫一个日新月异,局域网远程监控系统在企业管理里的地位越来越重要。它就像企业的一双 “透视眼”,不仅能实时瞅着员工电脑的使用情况,还能帮着提升工作效率,把企业信息安全捂得严严实实。今儿咱就好好聊聊,这局域网远程监控系统到底有啥吸引人的技术特点,又能给企业带来哪些好处。一、局域网远程监控系统是什么?简单讲,就...
你了解终端准入系统的多重作用吗?
企业仿佛是一艘在数据海洋中破浪前行的巨轮,而终端准入系统,无疑就是那艘船上恪尽职守的 “守门员”。你或许会心生疑惑:这个 “守门员” 究竟有何神通,竟能助力企业在数据的汪洋里安稳航行?别着急,咱们这就一同深入探讨终端准入系统的多样妙用,以及它为何如此举足轻重。一、技术特点:精准识别,严格把控终端准入系统,本质上就是一道...
怎样设置电脑文件不能被拷贝呢?(技巧和方法详解)
《庄子·逍遥游》中的句子:“吾生也有涯,而知也无涯。”在当前的无纸化信息时代,数据虽然信息无穷,但安全的保护有其界限,需要人们警觉和措施,现代数据安全中,不应轻视今天的安全,应当即刻采取措施防止未来的风险。作为老板你希望的核心数据泄露吗?那我们应该怎样防范呢?下面跟着小编来学习一下禁止流程和方法:方法一:通过修改注册表...