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

蓝桥杯之KMP算法

算法思想

代码实现

int* getnext()
{
	int* next = new int[s2.size()];
	int j = 0;//用来遍历子串
	int k = -1;//子串中公共子串的长度
	next[0] = -1;
	while (j < s2.size() - 1)
	{
		if (k==-1||s2[k] == s2[j])
		{
			k++;
			j++;
			if (s2[k] == s2[j])
			{
				next[j] = next[k];
			}
			else
			{
				next[j] = k;
			}
		}
		else
		{
			k = next[k];//做k值得回溯,继续找最长公共前后缀
		}
	}
	return next;
}
int KMP()
{
	{
		int i = 0;
		int j = 0;
		//是为了处理当j==-1时的情况
		int len1 = s1.size();
		int len2 = s2.size();
		int* next = getnext();
		while (i < len1 && j < len2)
		{
			if (j==-1||s1[i] == s2[j])
			{
				i++;
				j++;
			}
			else
			{
				j = next[j];
			}
		}
		if (j == s2.size())
		{
			return i - j;
		}
		else
		{
			return -1;
		}
	}
}
int main()
{
	int pos = KMP();
	cout << pos << endl;
	return 0;
}

http://www.dtcms.com/a/15869.html

相关文章:

  • 【Linux】环境变量
  • 【Python】从爬虫小白到大佬(一)
  • 玩转适配器模式
  • VMware Workstate 的 Ubuntu18 安装 vmware tools(不安装没法共享)
  • 【DeepSeek】DeepSeek R1 本地windows部署(Ollama+Docker+OpenWebUI)
  • 【数据结构-红黑树】
  • UE5.2后 Bake Out Materials失效
  • ong API Key 认证插件详解
  • 防火墙过滤漏洞问题
  • 【Java集合一】集合概述
  • vue3 关于插槽的使用
  • 给本地模型“投喂“数据
  • 我的新书《青少年Python趣学编程(微课视频版)》出版了!
  • [免费]Springboot+Vue医疗(医院)挂号管理系统【论文+源码+SQL脚本】
  • 单调队列及其相关题解
  • png、jpg、gif、webp的区别
  • 华为交换机堆叠配置
  • OpenAI发布新模型及会员订阅计划:o3-mini、GPT-4.5与GPT-5的全新体验
  • Java发展史
  • 强化学习之RLHF
  • 《深度学习》—— DataLoader数据处理、transforms
  • InfiniBand IPoIB 驱动中关键网络设备操作函数分析
  • JVM类加载和垃圾回收(详细)
  • 华为FreeBuds Pro4和FreeBuds Pro3区别,相比上一代升级了什么
  • 无需编码5分钟免费部署云上调用满血版DeepSeek
  • 微软官方出品GPT大模型编排工具:7个开源项目
  • Mybatisplus——Mybatisplus3.5.2版本使用Page分页插件查询,records有数据但是total显示0
  • 理解 WebGPU 的入口: navigator.gpu
  • API网关基础知识总结
  • C++学习 mac上VScode运行C++