字符串哈希
字符串哈希 常常可以处理一些用kmp难以处理的题目,是kmp的劲敌。
#include <iostream>
using namespace std;
const int N = 1e5 + 10,P = 131;
typedef unsigned long long ULL;
ULL h[N],p[N];
char str[N];
int m,n;
ULL check(int l, int r)
{
return h[r] - h[l - 1]*p[r - l + 1];
}
int main()
{
scanf("%d%d%s", &n, &m, str+1);
p[0] = 1;
for(int i = 1; i <= n; i ++)
{
p[i] = p[i - 1] * P;
//这里直接用assii码代表P进制数前面的系数
h[i] = h[i - 1] * P + str[i];
}
while(m--)
{
int l1, r1, l2, r2;
cin>>l1>>r1>>l2>>r2;
if(check(l1, r1) == check(l2, r2)) puts("Yes");
else puts("No");
}
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署