博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[BZOJ 3647]
阅读量:5127 次
发布时间:2019-06-13

本文共 1981 字,大约阅读时间需要 6 分钟。

BZOJ 3647——可持久化并查集加强版

不会可持久化并查集先去做.

幼稚的以为直接交原来的就好了,结果T了!

加个路径压缩,but一直RE,请了几位大神还是解决不了。。所以先留个坑。。

#include
#include
#include
using namespace std;#define maxn 300050int cnt=0,ls[maxn*40],rs[maxn*40],root[maxn],sz,key[maxn*40],n,m,i,v[maxn*40];int read(){ int w=0;char c=getchar(); while(c<48||c>57) c=getchar(); while(c>=48&&c<=57){ w=w*10+c-48; c=getchar(); } return w;}void build(int &p,int l,int r){ p=++cnt; if(l==r) {key[p]=l;return;} if(l!=r){ int mid=(l+r)/2; build(ls[p],l,mid); build(rs[p],mid+1,r); }}void Modify(int &p,int cmp,int l,int r,int loc,int val){ if(v[p]!=i){ p=++cnt;ls[p]=ls[cmp];rs[p]=rs[cmp];v[p]=i;} if(l==r){ key[p]=val; } if(l!=r){ int mid=(l+r)>>1; if(loc<=mid){ Modify(ls[p],ls[cmp],l,mid,loc,val); } else{ Modify(rs[p],rs[cmp],mid+1,r,loc,val); } }}inline int query(int version,int l,int r,int loc){ int mid; while(l!=r){ mid=(l+r)>>1; if(loc<=mid) version=ls[version],r=mid; else version=rs[version],l=mid+1; } return key[version];}int find(int version,int loc){ int fa=query(root[version],1,n,loc); if(fa==loc) return fa; int anc=find(version,fa); Modify(root[version],root[version],1,n,loc,anc); return anc;}int main(){ int x,y,l,r,k,opt,lastans=0; n=read();m=read(); build(root[0],1,n); for(i=1;i<=m;i++){ opt=read();x=read()^lastans; if(opt==1){ y=read()^lastans; Modify(root[i],root[i-1],1,n,find(root[i-1],x),find(root[i-1],y)); } else if(opt==2) root[i]=root[x]; else{ y=read()^lastans; root[i]=root[i-1]; lastans=(find(i,x)==find(i,y)); if(lastans) printf("1\n"); else printf("0\n"); } } //printf("%d\n",cnt);}

 

转载于:https://www.cnblogs.com/Fish-/p/8253032.html

你可能感兴趣的文章
ECMAScript6 Object
查看>>
NIOS II 中直接调用Modelsim仿真
查看>>
XPath 实例
查看>>
JavaScript操作符(布尔操作符、乘性操作符和加性操作符)
查看>>
浅谈JavaScript的事件(事件处理程序)
查看>>
前端知识小总结3
查看>>
curl模拟调用接口
查看>>
网页如何获取手机屏幕宽度
查看>>
WebGL中的函数及内置属性介绍
查看>>
【css学习整理】css基础(样式,语法,选择器)
查看>>
poj1450 Gridland
查看>>
站立会议(11月26日)
查看>>
hadoop学习之yarn资源管理
查看>>
PAT乙级1009.说反话(20)
查看>>
仿《雷霆战机》飞行射击手游开发--项目总览
查看>>
jmeter函数简介
查看>>
eclipse 快捷键
查看>>
md5和base64加密解密
查看>>
[ HNOI 2006 ] 公路修建问题
查看>>
[Paper] LCS: An Efficient Data Eviction Strategy for Spark
查看>>