在很多应用领域中,比如在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)。
随着网络的发展,模式匹配加密算法的应用越来越广,因而提高模式匹配加密算法的效率也是当前研究的热点。
小知识之模式匹配
筑牢安全防线:安企神企业助力特种设备机械企业数据防泄密解决方案
西安苛菲特机械设备有限公司 西安苛菲特机械设备有限公司致力于特种设备的发展,专业从事特种设备的研发、制造和销售。目前已成为有色冶金特种设备、大型船舶特种设备、煤化工特种设备的领军品牌,并在业内得到了“ 特种设备专家”的称号。公司以打造国内一流特种设备为使命,主要产品定型为高品质特种(高温、高压、高合金)流量控...
安企神软件——为中国铁道建筑集团有限公司筑牢数据防泄密系统
01公司介绍中国铁建是中国乃至全球最具实力、最具规模的特大型综合建设集团之一,入选世界500强企业、全球225家最大承包商之一等荣誉。公司以工程承包为主业,集勘察、设计、投融资、施工、设备安装、工程监理、技术咨询、外经外贸于一体,经营业务遍及除台湾省外全国31个省市(自治区)、世界20多个国家和地区,企业总资产820亿...
强化终端安全,安企神软件与涂料制造企业共创安全未来
西安经建油漆有限责任公司规模化、专业化、现代化涂料制造企业西安经建油漆有限责任公司,年涂料生产能力20万吨,为中国中西部实力较强、产能较大的涂料制造企业。公司成立伊始便积极承担起重点建设项目及国防军事工业、航空航天工业提供配套涂料科研开发及生产任务。多次受到中国航天科技集团总公司的通令嘉奖,为我国航天事业跻身世界前列做...
全球著名减震器制造商——天纳克携手安企神共筑安全制造新防线
天纳克(北京)汽车减振器有限公司天纳克(北京)汽车减振器有限公司成立于1995年,是天纳克在中国最早投资的合资企业。公司集设计、开发、生产及销售汽车减振器于一身。作为天纳克全球网络的一部分,能充分享受天纳克全球的技术积累经验和国际领先的设计理念,加之先进的生产设备和工艺技术。天纳克(北京)汽车减振器有限公司完全能保证为...
强强联合!安企神软件携手瀚颐共筑汽车行业终端安全防线
瀚颐上海汽车电子科技有限公司EAST瀚颐中国团队成立于2015年。是国际AUTOSAR软件联盟的研发伙伴单位。具备汽车电子硬件设计、软件开发、CAN网络集成、系统集成测试以及项目管理的全面研发能力。专注于汽车电子以及相关产业并拥有25年以上的专业经验,拥有来自于德国和中国业内专家和高管组成的顾问团队,并向全球汽车行业客...