当前位置: 首页 > news >正文

【算法——KMP】

1理解next数组定义:最长相等前后缀(不含当前字符并且不能是整体)

算法讲解100【扩展】 KMP算法原理和代码详解_哔哩哔哩_bilibili

next数组的值:假设这个i出现了不匹配就从next[i]的位置开始在再匹配

2next数组生成

 看一下是怎么跳的:算法讲解100【扩展】 KMP算法原理和代码详解_哔哩哔哩_bilibili

为什么这么跳:算法讲解100【扩展】 KMP算法原理和代码详解_哔哩哔哩_bilibili

next代码:算法讲解100【扩展】 KMP算法原理和代码详解_哔哩哔哩_bilibili

#include<iostream>
#include<vector>
#include<algorithm>
#include<string>
using namespace std;vector<int> fun_next(string str1)    //next生成
{vector<int>next(str1.size());next[0] = -1;next[1] = 0;int i = 2, cn = 0;while (i < str1.size()){if (str1[i - 1] == str1[cn])next[i++] = ++cn;   else if (cn > 0)   //一次不成功,cn还可以往前跳 。cn为0说明没有前后缀,下一个就是0了 cn = next[cn];  else next[i++] = 0;}return next;
}int main()
{string str1("abcabc");string str2("afdfabcabcghj");vector<int>next = fun_next(str1);for (auto i : next)cout << i << " ";cout << endl;int m = str1.size(), n = str2.size();int i = 0, j = 0;while (i < m && j < n)   //匹配{if (str1[i] == str2[j]){i++; j++;}else if (i == 0)j++;elsei = next[i];}if (i == m)cout << "找到了:" << j - i;elsereturn -1;return 0;
}

http://www.lryc.cn/news/445057.html

相关文章:

  • 视频监控相关笔记
  • React 中,构建组件的方式
  • Android开发高频面试题之——Android篇
  • 禁用拷贝构造函数和赋值构造函数
  • OneDrive for Business with Office Online 部署方案
  • win10 win11 设置文件权限以解决Onedrive不能同步问题
  • Unity DOTS系列之IJobChunk来迭代处理数据
  • 哈希——哈希表
  • 简单了解 JVM
  • 已经30岁了,想转行从头开始现实吗?什么样的工作算好工作?
  • 快速理解docker(一)docker 简介
  • RHCS认证-Linux(RHel9)-Ansible
  • 【Python】Spyder:科学 Python 开发环境
  • SpringBootWeb响应
  • CMake 构建Qt程序弹出黑色控制台
  • 虚拟机centos_7 配置教程(镜像源、配置centos、静态ip地址、Finalshell远程操控使用)
  • git 删除 git push 失败的记录
  • 【专题】2024年中国白酒行业数字化转型研究报告合集PDF分享(附原数据表)
  • 哪款品牌充电宝性价比比较高?五款性价比绝佳充电宝推荐
  • 巨坑!!华为大数据平台sparksql,连接gauss200数据库
  • BGP相关知识笔记
  • 在 Windows 上运行 Vue 项目时解决 ‘NODE_OPTIONS‘ 错误
  • 面试真题:谈一谈Mysql的分库分表
  • 玄机靶场--蚁剑流量
  • uniapp map设置高度为100%后,会拉伸父容器的高度
  • CICD从无到会
  • 责任链模式优化 文章发布的接口(长度验证,敏感词验证,图片验证等环节) 代码,示例
  • Java流程控制语句——条件控制语句详解(附有流程图)#Java条件控制语句有哪些?#if-else、switch
  • 十一、SOA(SOA的具体设计模式)
  • Mybatis原理