题目链接:Problem - 5685 (hdu.edu.cn)
题目:
题目样例:
题目思路:
先预处理1到所有长度的哈希值,存入到乘法的前缀和数组里(不进行预处理会超时)。在查询的时候取sum[b]/sum[a-1],即是a到b的哈希值。除的时候需要逆元处理。
AC:
#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int N=1e5+5;
int n,a,b,x,y;
int sum[N],ans[N];
string s;
int ex_gcd(int a,int b,int &x,int &y){
if(b==0){
x=1;
y=0;
return a;
}
int d=ex_gcd(b,a%b,x,y);
int tmp=x;
x=y;
y=tmp-(a/b)*y;
return d;
}
int main(){
while(cin>>n){
sum[0]=1;
ans[0]=1;
cin>>s;
int len=s.size();
for(int i=0;i<len;i++){
int nn=s[i];
sum[i+1]=sum[i]*(nn-28)%9973;
}
while(n--){
cin>>a>>b;
ex_gcd(sum[a-1],9973,x,y);
x=(x%9973+9973)%9973;
cout<<(sum[b]*x)%9973<<endl;
}
}
return 0;
}