【NOIP2017提高组模拟6.27】C
题目
蜘蛛精大爷是世界上最爷的爷,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的更多相关文章
- JZOJ 5184. 【NOIP2017提高组模拟6.29】Gift
5184. [NOIP2017提高组模拟6.29]Gift (Standard IO) Time Limits: 1000 ms Memory Limits: 262144 KB Detailed ...
- NOIP2017提高组 模拟赛15(总结)
NOIP2017提高组 模拟赛15(总结) 第一题 讨厌整除的小明 [题目描述] 小明作为一个数学迷,总会出于数字的一些性质喜欢上某个数字,然而当他喜欢数字k的时候,却十分讨厌那些能够整除k而比k小的 ...
- JZOJ 5196. 【NOIP2017提高组模拟7.3】B
5196. [NOIP2017提高组模拟7.3]B Time Limits: 1000 ms Memory Limits: 262144 KB Detailed Limits Goto Pro ...
- JZOJ 5197. 【NOIP2017提高组模拟7.3】C
5197. [NOIP2017提高组模拟7.3]C Time Limits: 1000 ms Memory Limits: 262144 KB Detailed Limits Goto Pro ...
- JZOJ 5195. 【NOIP2017提高组模拟7.3】A
5195. [NOIP2017提高组模拟7.3]A Time Limits: 1000 ms Memory Limits: 262144 KB Detailed Limits Goto Pro ...
- 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 ...
- NOIP2017提高组 模拟赛13(总结)
NOIP2017提高组 模拟赛13(总结) 第一题 函数 [题目描述] [输入格式] 三个整数. 1≤t<10^9+7,2≤l≤r≤5*10^6 [输出格式] 一个整数. [输出样例] 2 2 ...
- NOIP2017提高组模拟赛 10 (总结)
NOIP2017提高组模拟赛 10 (总结) 第一题 机密信息 FJ有个很奇怪的习惯,他把他所有的机密信息都存放在一个叫机密盘的磁盘分区里,然而这个机密盘中却没有一个文件,那他是怎么存放信息呢?聪明的 ...
- NOIP2017提高组模拟赛 8(总结)
NOIP2017提高组模拟赛 8(总结) 第一题 路径 在二维坐标平面里有N个整数点,Bessie要访问这N个点.刚开始Bessie在点(0,0)处. 每一步,Bessie可以走到上.下.左.右四个点 ...
随机推荐
- 卸载openssl后yum无法使用,ssh无法连接的解决办法
一,安装nginx时,提示openssl版本问题,用yum update openssl 发现还是不行,于是rpm -e 卸载了openssl 此时,才发现yum不能用了,然后想上传个tar包时又出现 ...
- c++ STL 【更新...】
STL STL(标准模板库)是一套功能强大的 C++ 模板类,提供了通用的模板类和函数,这些模板类和函数可以实现多种流行和常用的算法和数据结构 核心包括以下三个组件: 容器(Containers) 容 ...
- DSP28335 GPIO学习
根据网络资料以及以下两篇博客整理 http://blog.sina.com.cn/s/blog_86a6035301017rr7.html http://blog.csdn.net/hmf123578 ...
- docker mysql 容器报too many connections 引发的liunx磁盘扩容操作
症状每次删除mysql容器重启没两分钟又报标题错 df -h 命令查看各个挂载空间应用情况发现root home var 三个文件目录挂载的空间满了 网上百度了一下liunx磁盘扩容操作,fdisk ...
- 20191224 Spring官方文档(Core 1.1-1.4)
1. IoC容器 1.1.Spring IoC容器和Bean简介 org.springframework.beans和org.springframework.context包是Spring框架的IoC ...
- [转帖]站点部署,IIS配置优化指南
站点部署,IIS配置优化指南 https://www.cnblogs.com/heyuquan/p/deploy-iis-set-performance-guide.html 挺值得学习的 毕竟之前很 ...
- idea运行时 Process finished with exit code -1073741819 (0xC0000005)
问题描述: idea中启动项目报 Process finished with exit code -1073741819 (0xC0000005) ,如图所示: 问题解决: ...
- vue-loader介绍和单页组件介绍
$ \es6\sing-file> npm install vue-loader@14.1.1 -D vue-template-compiler@2.5.17 -D npm install v ...
- adb 设置安卓连接wifi
一. 修改wpa_supplicant.conf文件 1.1. 获得root权限 adb root 1.2. 将wpa_supplicant.conf拷贝到你的电脑 adb pull /data/mi ...
- 打印输出opencv的版本信息
本文链接: https://mangoroom.cn/opencv/print-opencv-version-info.html 序 查看自己安装的opencv的版本信息的方法有两种. 方法一-查看l ...