2021第一篇博客&luogu第一篇博客:
具体看金策和_sys的题解吧
主要要把 2 k 2^k 2k长度内 [ l , r ] [l,r] [l,r]的各种本质不同形如 i , i + 2 k − 1 i,i+2^k-1 i,i+2k−1子串的等差数列求出来,查询用哈希查。
时空复杂度 O ( N l o g N ) O(NlogN) O(NlogN)
好吧水完一篇博客了,提交的时候是跑得最快的,代码长度4K,性价比还行,感觉这份代码就是后缀数组+等差数列的维护。
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
#define rep(i,a,b) for(int i=(a);i<=(b);++i)
#define per(i,a,b) for(int i=(a);i>=(b);--i)
int n,q;
#define Maxn 200010
#define NlogN 4000010
#define cout cerr
#define FR first
#define SE second
int S[Maxn];char ch[Maxn];
int rk[Maxn][20];
namespace HS{
const int hs_mod=1e7+9;
const int base=233333;
int head[hs_mod],nxt[NlogN],tot=0;
pii a[NlogN];int b[NlogN];
void Add(pii x,int y){
int key=(1ll*x.FR*base+x.SE)%hs_mod;
tot++;a[tot]=x;b[tot]=y;nxt[tot]=head[key];head[key]=tot;
}
int query(pii x){
int key=(1ll*x.FR*base+x.SE)%hs_mod;
for(int i=head[key];i;i=nxt[i])
if(a[i]==x)return b[i];
return 0;
}
}
struct dat{
int st,dt,l;
dat(){
st=l=0;dt=100;}
dat(int _st,int _dt,int _l){
st=_st;dt=_dt;l=_l;}
bool on(int x){
return x>=st&&(x-st)%dt==0&&(x