luogu4482 区间border

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+2k1子串的等差数列求出来,查询用哈希查。

时空复杂度 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
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值