您的位置:首页 > 其它

bzoj 5288: [Hnoi2018]游戏

2018-04-16 16:51 357 查看

Description



Solution

乱搞能A的题,毁我青春

记忆化一下扩展过程

只要不是从 \(1\) 枚举到 \(n\) 去扩展都可以 \(AC\)

于是 \(random\_shuffle\) 一下扩展顺序就过了

复杂度应该是启发式合并的复杂度

#include<bits/stdc++.h>
using namespace std;
const int N=1e6+10;
int n,a
,L
,R
,m,Q,p
;
inline void solve(int x){
int l=x,r=x;
while(1){
if(l>1 && ((l<=a[l-1] && a[l-1]<=r) || !a[l-1])){
l--;
l=min(l,L[l]);r=max(r,R[l]);
continue;
}
if(r<n && ((l<=a[r] && a[r]<=r) || !a[r])){
r++;
l=min(l,L[r]);r=max(r,R[r]);
continue;
}
break;
}
L[x]=l;R[x]=r;
}
int main(){
freopen("game.in","r",stdin);
freopen("game.out","w",stdout);
srand(19260859);
int x,y;
cin>>n>>m>>Q;
for(int i=1;i<=m;i++)
scanf("%d%d",&x,&y),a[x]=y;
for(int i=1;i<=n;i++)L[i]=n+1;
for(int i=1;i<=n;i++)p[i]=i;
for(int i=1;i<=5;i++)random_shuffle(p+1,p+n+1);
for(int i=1;i<=n;i++)solve(p[i]);
while(Q--){
scanf("%d%d",&x,&y);
if(L[x]<=y && y<=R[x])puts("YES");
else puts("NO");
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: