范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

图解KMP字符串匹配算法

  kmp算法跟之前讲的bm算法思想有一定的相似性。之前提到过,bm算法中有个好后缀的概念,而在kmp中有个好前缀的概念,什么是好前缀,我们先来看下面这个例子。
  观察上面这个例子,已经匹配的abcde称为好前缀,a与之后的bcde都不匹配,所以没有必要再比一次,直接滑动到e之后即可。
    那如果前缀中有互相匹配的字符呢?
  观察上面这个例子,这个时候如果我们直接滑到好前缀之后,则会过度滑动,错失匹配子串。那我们如何根据好前缀来进行合理滑动?
    其实就是看当前的好前缀的前缀和后缀是否有匹配的,找到最长匹配长度,直接滑动。鉴于不止一次找最长匹配长度,我们完全可以先初始化一个数组,保存在当前好前缀情况下,最长匹配长度是多少,这时候我们的next数组就出来了。
    我们定义一个next数组,表示在当前好前缀下,好前缀的前缀和后缀的最长匹配子串长度,这个最长匹配长度表示这个子串之前已经匹配过匹配了,不需要再次进行匹配,直接从子串的下一个字符开始匹配。
   我们是否每次算next[i]时都需要每一个字符进行匹配,是否可以根据next[i - 1]进行推导以便减少不必要的比较。
    带着这个思路我们来看看下面的步骤:
    假设next[i - 1] = k - 1;
    如果modelStr[k] = modelStr[i] 则next[i]=k
  如果modelStr[k] != modelStr[i],我们是否可以直接认定next[i] = next[i - 1]?
  通过上面这个例子,我们可以很清晰地看到,next[i]!=next[i-1],那当modelStr[k]!=modelStr[i]时候,我们已知next[0],next[1]…next[i-1],如何推导出next[i]呢?
    假设modelStr[x…i]是前缀后缀能匹配的最长后缀子串,那么最长匹配前缀子串为modelStr[0…i-x]
  我们在求这个最长匹配串的时候,他的前面的次长匹配串(不包含当前i的),也就是modelStr[x…i-1]在之前应该是已经求解出来了的,因此我们只需要找到这个某一个已经求解的匹配串,假设前缀子串为modelStr[0…i-x-1],后缀子串为modelStr[x…i-1],且modelStr[i-x] == modelStr[i],这个前缀后缀子串即为次前缀子串,加上当前字符即为最长匹配前缀后缀子串。
  代码实现
    首先在kmp算法中最主要的next数组,这个数组标志着截止到当前下标的最长前缀后缀匹配子串字符个数,kmp算法里面,如果某个前缀是好前缀,即与模式串前缀匹配,我们就可以利用一定的技巧不止向前滑动一个字符,具体看前面的讲解。我们提前不知道哪些是好前缀,并且匹配过程不止一次,因此我们在最开始调用一个初始化方法,初始化next数组。
    1.如果上一个字符的最长前缀子串的下一个字符==当前字符,上一个字符的最长前缀子串直接加上当前字符即可
    2.如果不等于,需要找到之前存在的最长前缀子串的下一个字符等于当前子串的,然后设置当前字符子串的最长前缀后缀子串int[] next ;     /**      * 初始化next数组      * @param modelStr      */     public void init(char[] modelStr) {         //首先计算next数组         //遍历modelStr,遍历到的字符与之前字符组成一个串         next = new int[modelStr.length];         int start = 0;         while (start < modelStr.length) {             next[start] = this.recursion(start, modelStr);             ++ start;         }     }       /**      *      * @param i 当前遍历到的字符      * @return      */     private int recursion(int i, char[] modelStr) {         //next记录的是个数,不是下标         if (0 == i) {             return 0;         }         int last = next[i -1];         //没有匹配的,直接判断第一个是否匹配         if (0 == last) {             if (modelStr[last] == modelStr[i]) {                 return 1;             }             return 0;         }         //如果last不为0,有值,可以作为最长匹配的前缀         if (modelStr[last] == modelStr[i]) {             return next[i - 1] + 1;         }         //当next[i-1]对应的子串的下一个值与modelStr不匹配时,需要找到当前要找的最长匹配子串的次长子串         //依据就是次长子串对应的子串的下一个字符==modelStr[i];         int tempIndex = i;         while (tempIndex > 0) {             last = next[tempIndex - 1];             //找到第一个下一个字符是当前字符的匹配子串             if (modelStr[last] == modelStr[i]) {                 return last + 1;             }             -- tempIndex;         }         return 0;     }
  然后开始利用next数组进行匹配,从第一个字符开始匹配进行匹配,找到第一个不匹配的字符,这时候之前的都是匹配的,接下来先判断是否已经是完全匹配,是直接返回,不是,判断是否第一个就不匹配,是直接往后面匹配。如果有好前缀,这时候就利用到了next数组,通过next数组知道当前可以从哪个开始匹配,之前的都不用进行匹配。public int kmp(char[] mainStr, char[] modelStr) {         //开始进行匹配         int i = 0, j = 0;         while (i + modelStr.length <= mainStr.length) {             while (j < modelStr.length) {                 //找到第一个不匹配的位置                 if (modelStr[j] != mainStr[i]) {                     break;                 }                 ++ i;                 ++ j;             }             if (j == modelStr.length) {                 //证明完全匹配                 return i - j;             }             //走到这里找到的是第一个不匹配的位置             if (j == 0) {                 ++ i;                 continue;             }             //从好前缀后一个匹配             j = next[j - 1];         }         return -1;     }

长续航加大屏幕的远程办公高效利器,LGgram17体验近年来,居家办公已经成为了常态,但家里的设备没有公司的强,办公的效率可能没有在公司的效率高,所以很多打工人不得已将公司里笨重的主机抱回家办公。毕竟市面上的所谓轻薄办公本性能实在太差智能厨电一站购齐云米联合京东打造未来智慧厨房有人曾预言过,当人们迈入智能时代时,首先能给他们带来具体感受的场景就是厨房。而如今看来,这一观点也在逐渐得到应验。就在近期,国内智能家电领导品牌云米与电商巨头京东宣布正式开展深度合苹果向开发者发布macOSMonterey12。4Beta2苹果公司今天向开发者发布了macOSMonterey12。4的第二个测试版,用于测试目的,新的更新是在第一个macOSMonterey12。4Beta发布两周后推出的。注册开发者可VisualStudio2022v17。1。5发布VisualStudio2022v17。1。5正式发布,更新内容如下修正了17。1。4版本中vctip。exe的回归问题修正了无法在离线机器上安装VisualStudio的任何扩展科学家发现一种古老且珍贵的气体,正在从地球内部释放出来现代科学认为,我们的地球诞生于46亿年前,也就是太阳系诞生初期,在50亿年前,太阳系一片混乱,太阳诞生以后,吸收了周围大量的物质,所以太阳的质量占到了太阳系总质量的百分之99。86雷军二话不说,12512G直接再降1500,顶级骁龙888旗舰清场了小米今年的旗舰还有ultra版本MIX系列和折叠手机没有上线,根据曝光的消息,小米12ultra已经在路上了,而且今年的小米12ultra不仅在影像上大展拳脚,性能上也是独占鳌头的曾经一机难求,如今现货还降价,骁龙888Plus5000mAh,仅1799元注重性价比的网友都知道,如果某款手机的性价比极高,一般都意味着该机的低配版本上市初期会出现供不应求的问题,用网友们的话来说,这就是耍猴式营销,之所以会出现这种现状,主要是因为这些低黑科技聚集的比亚迪在全球经济下行的大背景下乘风破浪近日,比亚迪发布公告称,预计今年Q1净利润6。5亿元9。5亿元,同比增长174300。作为长期以中国新能源领导者自居的比亚迪,在我国经济发展面临需求收缩供给冲击预期转弱三重压力的大科学家人类正处于第六次生物大灭绝之中1998年,美国博物馆进行过一次调查,大约有70的人认为人类正处于大灭绝事件中。虽然,第六次大灭绝的概念在此之前很早就已经被提出,但是在这次调查之后,这样的概念更频繁地出现在一些报知乎视频迷途降权团队解散一号位离职来源Tech星球文翟元元我们将持续进行视频化战略,进一步推动内容社区的壮大,去年上市后首个财报电话会议上,知乎创始人兼CEO周源曾对外宣布知乎视频业务未来的规划。彼时,视频业务各项小米开售米家智能无叶净化扇,售价1599元4月20日消息,在此前小米曾经在商城上架了一款米家智能无叶净化扇的众筹活动,而目前这一款产品已经正式上架销售,售价为1599元。根据商品页面的介绍显示,米家智能无叶净化扇采用净化循
币圈人怎么评估一个区块链游戏靠不靠谱?得看三件套和四大点如果区块链游戏要吸引币圈的用户去体验,一定要具备几个要素,下面是三件套区块链平台交易所和钱包。以下经验来自一位币圈人士和游戏厂商的分享。首先区块链平台是说要有一条运行区块链游戏的区DApp游戏排行可以去哪里看?许多刚触碰DApp游戏的朋友最初都是有这类疑惑究竟哪儿能寻找比较好的DApp游戏?有没有好点的链游推荐?今日给大伙儿推荐一些我平常上的网址,让诸位自身还可以去挖掘自身喜爱的DApp必须具备这三点才能称作真正意义上的区块链游戏那麼究竟什么叫真实实际意义上的区块链游戏?真实的区块链游戏应具有三点。最先是要以区块链技术为支撑点,仅有将区块链技术真实的应用到游戏之中去,这款游戏才能够称作是区块链游戏,而现阶段DAPP想要发展,还需要解决这些根本问题社会持续的发展交替,促使区块链技术已经搭建一个全新升级的世界。伴随着区块链技术风潮,愈来愈多的人觉得DAPP将是互联网技术的将来。从迷恋猫到Fomo3d,大家印证了DAPP的快速扩病毒式的营销概念,讲讲为何区块链挖矿游戏会一夜爆火区块链是一门去中心化的技术,游戏与区块链融合的区块链挖矿游戏,便是把游戏财产使用权从游戏公司迁移到每一个游戏玩家手上,确保游戏玩家的利益。区块链挖矿游戏的定义是由第一款裂变式取得成赵长江特斯拉的牌打完了,轮到我们出牌了2020年第一季度,特斯拉新能源车销量全球第一。近两个月来,特斯拉风波不断。芯片降级事件曝光引起的硬件减配高管被约谈国产等一系列事件,都预示着国产特斯拉还隐藏着更多秘密。随后,明星BPIM5开发板,8K视频解码四核A55安卓9。0大家好,我是芯板坊小月月,今天带来一款BananaPiBPIM5开发板。板卡介绍BananaPiBPIM5是新一代单板计算机设计,采用AmlogicS905X3四核CortexA5HRflag2021苏州人力资源峰会成功举办2021年9月6日,苏州由中国领先的人力资源管理智库HRflag举办的苏州人力资源峰会(SUZHOUHRSummit)于9月3日在苏州香格里拉大酒店成功举办!视频加载中2021HR直播预约ampampquot旗思妙谈ampampquot生物梅里埃人力资源高级副总裁张群丽女士由中国领先的人力资源管理智库HRflag重磅启动的旗思妙谈CHO系列访谈第44期访谈项目将于2021年8月24日(今日)晚1930重磅开启直播!本期访谈主办方重磅邀请全球领先的微生100,945次观看!HRflag2021快消与连锁行业人力资源峰会圆满落幕2021年9月10日,上海由中国领先的人力资源管理智库HRflag主办的快消与连锁行业大规模高层次的人力资源线上峰会快消与连锁行业人力资源峰会于9月9日圆满落下帷幕!这场为期两天的2021极帜奖(FLAGAwards)盛大揭晓2021年9月17日,上海人力资源经理人团队项目年度旗帜性奖项2021极帜奖(FlagAwards)颁奖典礼于9月16日在上海香格里拉酒店隆重举行!本年度荣膺奖项的高管团队来自48