题目

蜘蛛精大爷是世界上最爷的爷,ta的图论专著《蜘蛛精大爷教你学做人OI之图论》正在热卖,只要233美元一本,每人限购一本。。。。。。在某弱的不懈要求下,ta给某弱出了一道题,然而某弱太弱了,只好向你求助。

给你一张n个结点,m条边的无向图,每个结点都有一个整数权值。你需要执行一系列操作。操作分为三种,如下表所示。

操作

D x (1<=x<=m)

删除编号为x的边。输入保证每条边至多被删除一次。

Q x k (1<=x<=n)

计算出结点x所在的联通块中,第k大的权值。如果不存在,输出0。

C x v (1<=x<=n)

把结点x的权值改为v。

操作序列的结束标志为单个字母E。结点编号为1到n,边的编号为1到m。

分析

考虑到,求第k大,我们可以用权值线段树,

线段树分裂很麻烦,

所以,倒过来做。

首先先将没有被删除的边加入,用并查集维护,

对于每一个联通块开一棵线段树,

在将经过多次修改后的权值扔进这个节点所在的联通块的线段树。

这就是初始化了。

每当有D操作,如果这条边两边的点不在同一个联通块,用并查集并在一起,并将两个联通块的线段树合并。

Q操作就直接查询,记录在一个数组,最后倒着输出。

C操作,就在线段树中删除该值,加入修改的值。

#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
const long long maxlongint=2147483647ll;
const long long mo=1000000007;
const long long N=2000005;
const long long M=60010;
using namespace std;
long long tr[N][2],root[N],fa[N],b[N][2],size[N],n,m,re[N][3],tot,num,sum,d[N+10],t,v[N];
long long ans[N];
bool bz[N]={0};
long long read(long long &n)
{
char ch=' ';int q=0,w=1;
for(;(ch!='-')&&((ch<'0')||(ch>'9'));ch=getchar());
if(ch=='-')w=-1,ch=getchar();
for(;ch>='0' && ch<='9';ch=getchar())q=q*10+ch-48;n=q*w;return n;
}
void put(long long v,long long l,long long r,long long x,long long y)
{
if(l==r)
{
size[v]+=y;
return;
}
long long mid=(l+r)/2;
if(x<=mid)
{
if(!tr[v][0]) tr[v][0]=++tot;
put(tr[v][0],l,mid,x,y);
}
else
{
if(!tr[v][1]) tr[v][1]=++tot;
put(tr[v][1],mid+1,r,x,y);
}
size[v]+=y;
}
long long get(long long x)
{
if(fa[x]==x) return x;
return (fa[x]=get(fa[x]));
}
long long mesh(long long x,long long y)
{
if (!x) return y;
if (!y) return x;
size[x]+=size[y];
tr[x][0]=mesh(tr[x][0],tr[y][0]);
tr[x][1]=mesh(tr[x][1],tr[y][1]);
return x;
}
bool qq=true;
long long find(long long v,long long l,long long r,long long y)
{ if(l==r) return l;
long long mid=(l+r)/2;
if(y<=size[tr[v][1]]) return find(tr[v][1],mid+1,r,y);
else
return find(tr[v][0],l,mid,y-size[tr[v][1]]);
}
int main()
{
scanf("%lld%lld",&n,&m);
for(long long i=1;i<=n;i++)
read(v[i]),fa[i]=i,root[i]=++tot;
for(long long i=1;i<=m;i++)
for(long long j=0;j<=1;j++) read(b[i][j]);
while(1)
{
char c=getchar();
while(c!='E' && c!='D' && c!='Q' && c!='C') c=getchar();
if(c=='E') break;
read(re[++num][1]);
if(c=='D') bz[re[num][1]]=true;
else
if(c=='Q') re[num][0]=1,read(re[num][2]);
else
{
re[num][0]=2,read(re[num][2]);
long long x=re[num][2];
re[num][2]=v[re[num][1]];
v[re[num][1]]=x;
}
}
long long ff=maxlongint*2;
for(long long i=1;i<=n;i++) v[i]+=maxlongint;
for(int i=1;i<=num;i++)
if(re[i][0]==2) re[i][2]+=maxlongint;
for(int i=1;i<=m;i++)
if(!bz[i]) fa[get(b[i][1])]=get(b[i][0]);
for(int i=1;i<=n;i++) put(root[get(i)],0,ff,v[i],1);
for(int i=num;i>=1;i--)
{
if(!re[i][0])
{
int z=re[i][1],xx=get(b[z][0]),yy=get(b[z][1]);
if(xx==yy) continue;
mesh(root[xx],root[yy]);
fa[yy]=xx;
}
else
if(re[i][0]==1)
{
if(re[i][2]>size[root[get(re[i][1])]]) ans[++sum]=maxlongint;
else ans[++sum]=find(root[get(re[i][1])],0,maxlongint*2,re[i][2]);
qq=false;
}
else
{
put(root[get(re[i][1])],0,ff,v[re[i][1]],-1);
v[re[i][1]]=re[i][2];
put(root[get(re[i][1])],0,ff,v[re[i][1]],1);
} }
for(int i=sum;i>=1;i--) printf("%lld\n",ans[i]-maxlongint);
}

【NOIP2017提高组模拟6.27】C的更多相关文章

  1. JZOJ 5184. 【NOIP2017提高组模拟6.29】Gift

    5184. [NOIP2017提高组模拟6.29]Gift (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed ...

  2. NOIP2017提高组 模拟赛15(总结)

    NOIP2017提高组 模拟赛15(总结) 第一题 讨厌整除的小明 [题目描述] 小明作为一个数学迷,总会出于数字的一些性质喜欢上某个数字,然而当他喜欢数字k的时候,却十分讨厌那些能够整除k而比k小的 ...

  3. JZOJ 5196. 【NOIP2017提高组模拟7.3】B

    5196. [NOIP2017提高组模拟7.3]B Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed Limits   Goto Pro ...

  4. JZOJ 5197. 【NOIP2017提高组模拟7.3】C

    5197. [NOIP2017提高组模拟7.3]C Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed Limits   Goto Pro ...

  5. JZOJ 5195. 【NOIP2017提高组模拟7.3】A

    5195. [NOIP2017提高组模拟7.3]A Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed Limits   Goto Pro ...

  6. JZOJ 5185. 【NOIP2017提高组模拟6.30】tty's sequence

    5185. [NOIP2017提高组模拟6.30]tty's sequence (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB ...

  7. NOIP2017提高组 模拟赛13(总结)

    NOIP2017提高组 模拟赛13(总结) 第一题 函数 [题目描述] [输入格式] 三个整数. 1≤t<10^9+7,2≤l≤r≤5*10^6 [输出格式] 一个整数. [输出样例] 2 2 ...

  8. NOIP2017提高组模拟赛 10 (总结)

    NOIP2017提高组模拟赛 10 (总结) 第一题 机密信息 FJ有个很奇怪的习惯,他把他所有的机密信息都存放在一个叫机密盘的磁盘分区里,然而这个机密盘中却没有一个文件,那他是怎么存放信息呢?聪明的 ...

  9. NOIP2017提高组模拟赛 8(总结)

    NOIP2017提高组模拟赛 8(总结) 第一题 路径 在二维坐标平面里有N个整数点,Bessie要访问这N个点.刚开始Bessie在点(0,0)处. 每一步,Bessie可以走到上.下.左.右四个点 ...

随机推荐

  1. java:maven(maven-ssm(聚合,分包开发))

    1.maven-ssm: maven-ssm_diy: pom.xml: <?xml version="1.0" encoding="UTF-8"?> ...

  2. neutron网络服务

    一.neutron 介绍: 1. Neutron 概述 传统的网络管理方式很大程度上依赖于管理员手工配置和维护各种网络硬件设备:而云环境下的网络已经变得非常复杂,特别是在多租户场景里,用户随时都可能需 ...

  3. Redis 入门 3.2.2 命令

    Redis 入门 3.2 字符串类型 3.2.2 命令 1. 获得符合规则的键名列表 SET key value GET key   SET和GET是Redis中最简单的两个命令,他们实现的功能和编程 ...

  4. unity拖尾粒子问题

    拖尾粒子有一个问题就是当设置父物体时候,拖动父物体,就没有拖尾效果了 此时只需设置Emitter Velocity的类型为 transform 就行了 还有一种设置simulation space类型 ...

  5. 【转】WEB技术发展简史

    [转]WEB技术发展简史 一.Web技术发展的第一阶段——静态文档 第一阶段的Web,主要是用于静态Web页面的浏览.用户使用客户机端的Web浏览器,可以访问Internet上各个Web站点,在每一个 ...

  6. P1936 【水晶灯火灵】

    lalala~~(才不会告诉你这是题面呢) 这题确实有点坑,第一遍穷举超时,然后就开始了漫漫找规律之路... 终于,在经过5分钟的纠结之后,我终于发现了这个神奇的规律,那就是 Fabonacci!!! ...

  7. heartbeat双主高可用

    一.基础配置 1.hostnamectl set-hostname node1 (node2) 2.[root@node1 ~]# cat /etc/hosts     192.168.40.128 ...

  8. [转帖]「白帽黑客成长记」Windows提权基本原理(下)

    「白帽黑客成长记」Windows提权基本原理(下) https://www.cnblogs.com/ichunqiu/p/10968674.html 提权.. 之前还在想 为什么 我的 sqlserv ...

  9. 你确定 SQL 查询都是以 SELECT 开始的?

    很多 SQL 查询都是以 SELECT 开始的. 不过,最近我跟别人解释什么是窗口函数,我在网上搜索"是否可以对窗口函数返回的结果进行过滤"这个问题,得出的结论是"窗口函 ...

  10. SpringBoot_01

    一.初识springboot 个人总结:springboot是一个开发更加便捷的spring的技术框架,通过引入启动器便可以快捷的让spring框架和其他框架进行整合, springboot很容易上手 ...