字符串Hash

Posted childezhe

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了字符串Hash相关的知识,希望对你有一定的参考价值。

初始化:

char s[N];
unsigned long long f[1000010],p[1000010];
scanf("%s",s+1);
int n=strlen(s+1);
p[0]=1;

计算:

for(int i=1;i<=n;i++)
{
    f[i]=f[i-1]*131+(s[i]-a+1);
    p[i]=p[i-1]*131;
}

读取哈希值:

int l,r;
scanf("%d%d",&l,&r);
f[r]-f[l-1]*p[r-l+1]//hash of l~r

以上是关于字符串Hash的主要内容,如果未能解决你的问题,请参考以下文章

在保持相同行为的同时隐藏 url 中的 #hash 片段?

hash 在 perl 中的用法(转载)

如何理解这段代码片段中的两对括号?

一致性哈希算法PHP测试片段

URL中的锚点(fragment片段标识符)是什么?(hash mark(#))(HTML 页面内定位)(之前学html不是学了吗?忘啦?)(SEO 搜索引擎优化)

大厂面试必问!HashMap 怎样解决hash冲突?