字符串哈希
字符串哈希的思想:
将字符串转换成数字的形式,例如ABCD,将它看成1234,如果转换成p进制的数字,则可以这样计算:1 * p3 + 2 * p2 + 3 * p1+ 4 * p0。由于数字比较大经常会模一个值,可以是2的64次方。通常选择进制p为131或者13331。
如果不想模2的64次方,可以直接用unsigned long long定义字符串哈希数组,溢出的时候就自动对2的64次方取模。
例题:
给出长度为n的字符串,再给出m次询问。问两段字符串是否相等。
#include <bits/stdc++.h>
using namespace std;
typedef unsigned long long ULL;
const int N = 1e5 + 10, P = 131;
int n, m;
char str[N];
ULL h[N], p[N];
ULL get(int l, int r)
{
return h[r] - h[l - 1] * p[r - l + 1];
}
int main()
{
cin >> n >> m >> str + 1;
p[0] = 1;
for(int i = 1; i <= n; i ++)
{
p[i] = p[i - 1] * P;
h[i] = h[i - 1] * P + str[i];
}
while(m --)
{
int l1, r1, l2, r2;
cin >> l1 >> r1 >> l2 >> r2;
if(get(l1, r1) == get(l2, r2)) cout << "YES" << endl;
else cout << "NO" << endl;
}
}