字符串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中的锚点(fragment片段标识符)是什么?(hash mark(#))(HTML 页面内定位)(之前学html不是学了吗?忘啦?)(SEO 搜索引擎优化)