社区讨论
主席树6分求助
P3919【模板】可持久化线段树 1(可持久化数组)参与者 2已保存回复 2
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 2 条
- 当前快照
- 1 份
- 快照标识符
- @locik931
- 此快照首次捕获于
- 2023/10/30 14:23 2 年前
- 此快照最后确认于
- 2023/11/05 01:44 2 年前
RT
只有sub2的第一个点过了
CPP#include<bits/stdc++.h>
using namespace std;
const int MX=21*1000000+10;
#define LL long long
#define inf 0x7fffffff
struct tk
{
int l,r;
int value;
}tree[MX];
int top=0;
int root[MX];
int n,m;
int w[MX];
inline int read()
{
int x=0,f=1;char ch=getchar();
while (!isdigit(ch)){if (ch=='-') f=-1;ch=getchar();}
while (isdigit(ch)){x=x*10+ch-48;ch=getchar();}
return x*f;
}
inline int create(int node)
{
tree[++top]=tree[node];
return top;
}
inline int build(int now,int l,int r)
{
top++;
now=top;
if(l==r)
{
tree[now].value=w[l];
return top;
}
int mid=(l+r)>>1;
tree[now].l=build(tree[now].l,l,mid);
tree[now].r=build(tree[now].r,mid+1,r);
return now;
}
inline int updata(int now,int l,int r,int x,int nval)
{
now=create(now);
if(l==r)
{
tree[now].value=nval;
}
else
{
int mid=(l+r)>>1;
if(x<=mid)
{
tree[now].l=updata(tree[now].l,l,mid,x,nval);
}
else
{
tree[now].l=updata(tree[now].r,mid+1,r,x,nval);
}
}
return now;
}
inline int query(int now,int l,int r,int x)
{
if(l==r)
{
return tree[now].value;
}
else
{
int mid=(l+r)>>1;
if(x<=mid) return query(tree[now].l,l,mid,x);
else return query(tree[now].r,mid+1,r,x);
}
}
int main()
{
//freopen("1.in","r",stdin);
//freopen("1.out","w",stdout);
n=read(),m=read();
for(int i=1;i<=n;i++)
{
w[i]=read();
}
root[0]=build(0,1,n);
for(int i=1;i<=m;i++)
{
int v1,cz,loc;
v1=read(),cz=read(),loc=read();
if(cz==1)
{
int nval;
nval=read();
root[i]=updata(root[v1],1,n,loc,nval);
}
else if(cz==2)
{
printf("%d\n", query(root[v1],1,n,loc));
root[i]=root[v1];
}
}
return 0;
}
回复
共 2 条回复,欢迎继续交流。
正在加载回复...