当前位置: 首页 > 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;
}

相关文章:

  • 【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
  • wordpress建设的是模板网站吗/查域名
  • WordPress又拍云联盟代码/seo竞价培训
  • 做网站资金来源是什么/海口seo快速排名优化
  • 南川网站建设/2023疫情最新情况
  • 做行政关注什么类型的网站/超级外链发布工具
  • 衡水网站建设 燕丰收/营销方案推广