「SCOI2011」棘手的操作
传送门
Description
有\(N\)个节点,标号从\(1\)到\(N\),这\(N\)个节点一开始相互不连通。第$ i\(个节点的初始权值为\)a_i$ ,接下来有如下一些操作:
U x y
加一条边,连接第 \(x\) 个节点和第\(y\) 个节点。
A1 x v
将第 \(x\) 个节点的权值增加 \(v\)。
A2 x v
将第 \(x\) 个节点所在的连通块的所有节点的权值都增加 \(v\)。
A3 v
将所有节点的权值都增加\(v\) 。
F1 x
输出第 \(x\) 个节点当前的权值。
F2 x
输出第 \(x\) 个节点所在的连通块中,权值最大的节点的权值。
F3
输出所有节点中,权值最大的节点的权值。
Solution
离线处理
对原序列进行重新排序,使得每次合并时,两个集合的存在区间恰好相邻
转化为简单的线段树区间修改+区间询问
Code
#include<bits/stdc++.h>
#define ll long long
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)>(b)?(b):(a))
#define pi std::pair<int,int>
#define reg register
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
}
const int MN=6e5+5;
int A[MN],Map[MN],fMap[MN];
struct Mapper
{
int fa[MN],L[MN],R[MN],suf[MN];
void init(int N)
{
reg int i;
for(i=1;i<=N;++i) fa[i]=L[i]=R[i]=i,suf[i]=-1;
}
int getf(int x){return fa[x]==x?x:fa[x]=getf(fa[x]);}
void insert(int x,int y)
{
x=getf(x);y=getf(y);
if(x==y) return;
suf[R[x]]=L[y];
L[y]=L[x];fa[x]=y;
}
bool vis[MN];
void getMap(int N)
{
memset(vis,0,sizeof vis);
reg int i,l,r,cnt=0;
for(i=1;i<=N;++i)if(!vis[i])
for(l=L[getf(i)];l>0;l=suf[l]) vis[fMap[++cnt]=l]=true;
for(i=1;i<=N;++i) Map[fMap[i]]=i;
}
}a;
struct Operation{int opt,x,y;}O[MN];
int readchar()
{
static char s[5];
scanf("%s",s+1);
if(s[1]=='U') return 1;
if(s[1]=='A') return 1+s[2]-'0';
if(s[1]=='F') return 4+s[2]-'0';
}
struct Union_Find
{
int fa[MN],L[MN],R[MN];
void init(int N)
{
reg int i;
for(i=1;i<=N;++i) fa[i]=i,L[i]=R[i]=Map[i];
}
int getf(int x)
{
return fa[x]==x?x:fa[x]=getf(fa[x]);
}
void combine(int x,int y)
{
x=getf(x);y=getf(y);if(x==y) return;
fa[x]=y;L[y]=min(L[y],L[x]);R[y]=max(R[x],R[y]);
}
pi get(int x)
{
x=getf(x);
return make_pair(L[x],R[x]);
}
}b;
struct SegTree
{
#define ls x<<1
#define rs x<<1|1
#define mid ((l+r)>>1)
int t[MN<<2],lazy[MN<<1];
void up(int x){t[x]=max(t[ls],t[rs]);}
void Build(int x,int l,int r)
{
if(l==r) return (void)(t[x]=A[fMap[l]]);
Build(ls,l,mid);Build(rs,mid+1,r);up(x);
}
void C(int x,int val){t[x]+=val,lazy[x]+=val;}
void down(int x){if(lazy[x])C(ls,lazy[x]),C(rs,lazy[x]),lazy[x]=0;}
void Modify(int x,int l,int r,int a,int b,int val)
{
if(l==a&&r==b) return (void)(C(x,val));down(x);
if(b<=mid) Modify(ls,l,mid,a,b,val);
else if(a>mid) Modify(rs,mid+1,r,a,b,val);
else Modify(ls,l,mid,a,mid,val),Modify(rs,mid+1,r,mid+1,b,val);
up(x);
}
int Query(int x,int l,int r,int a,int b)
{
if(l==a&&r==b) return t[x];down(x);
if(b<=mid) return Query(ls,l,mid,a,b);
else if(a>mid) return Query(rs,mid+1,r,a,b);
else return max(Query(ls,l,mid,a,mid),Query(rs,mid+1,r,mid+1,b));
}
}c;
int main()
{
reg int i,N=read(); a.init(N);
for(i=1;i<=N;++i) A[i]=read();
reg int M=read();
for(i=1;i<=M;++i)
{
O[i].opt=readchar();
if(O[i].opt<7) O[i].x=read();
if(O[i].opt<4) O[i].y=read();
if(O[i].opt==1) a.insert(O[i].x,O[i].y);
}
a.getMap(N);c.Build(1,1,N);b.init(N);pi xxx;
for(i=1;i<=M;++i)
{
if(O[i].opt==1) b.combine(O[i].x,O[i].y);
if(O[i].opt==2) c.Modify(1,1,N,Map[O[i].x],Map[O[i].x],O[i].y);
if(O[i].opt==3) xxx=b.get(O[i].x),c.Modify(1,1,N,xxx.first,xxx.second,O[i].y);
if(O[i].opt==4) c.Modify(1,1,N,1,N,O[i].x);
if(O[i].opt==5) printf("%d\n",c.Query(1,1,N,Map[O[i].x],Map[O[i].x]));
if(O[i].opt==6) xxx=b.get(O[i].x),printf("%d\n",c.Query(1,1,N,xxx.first,xxx.second));
if(O[i].opt==7) printf("%d\n",c.Query(1,1,N,1,N));
}
return 0;
}
Blog来自PaperCloud,未经允许,请勿转载,TKS!
「SCOI2011」棘手的操作的更多相关文章
- BZOJ 2333 【SCOI2011】 棘手的操作
题目链接:棘手的操作 网上的题解大部分都是在线用可并堆艹……但是树高严格\(\log\)的可并堆我不会啊……还是离线大法好…… 我们可以先把所有的合并操作用并查集给处理好,把得到的森林记录下来.然后, ...
- 【BZOJ2333】【SCOI2011】棘手的操作 treap合并
题目大意 有\(n\)个节点,标号从1到\(n\),这\(n\)个节点一开始相互不连通.第\(i\)个节点的初始权值为\(a_i\),接下来有如下一些操作: \(U~x~y\):加一条边,连接第\(x ...
- 「SCOI2011」糖果
蒟蒻又回来写题解了... 题面 幼儿园里有 N 个小朋友, lxhgww 老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红 ...
- 【bzoj2333】 [SCOI2011]棘手的操作 可并堆+lazy标记
2016-05-31 21:45:41 题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2333 (学习了黄学长的代码 有如下操作: U x y ...
- 【BZOJ 2333 】[SCOI2011]棘手的操作(离线+线段树)
2333: [SCOI2011]棘手的操作 Description 有N个节点,标号从1到N,这N个节点一开始相互不连通.第i个节点的初始权值为a[i],接下来有如下一些操作: U x y: 加一条边 ...
- 2333: [SCOI2011]棘手的操作[写不出来]
2333: [SCOI2011]棘手的操作 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1979 Solved: 772[Submit][Stat ...
- 2333: [SCOI2011]棘手的操作[离线线段树]
2333: [SCOI2011]棘手的操作 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2325 Solved: 909[Submit][Stat ...
- 2333: [SCOI2011]棘手的操作[我不玩了]
2333: [SCOI2011]棘手的操作 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1979 Solved: 772[Submit][Stat ...
- 【BZOJ 2333 】[SCOI2011]棘手的操作(离线+线段树|可并堆-左偏树)
2333: [SCOI2011]棘手的操作 Description 有N个节点,标号从1到N,这N个节点一开始相互不连通.第i个节点的初始权值为a[i],接下来有如下一些操作: U x y: 加一条边 ...
随机推荐
- Mycat分布式数据库架构解决方案--Server.xml详解
echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 该文件 ...
- input file 无法打开手机端文件选择器
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/m0_37805167/article/details/78538044手机端对input file的 ...
- 【转载】C#中string类使用Substring方法截取字符串
在C#的字符串操作过程中,截取字符串是一种常见的字符串操作,可使用string类的Substring方法来完成字符串的截取操作,该方法支持设定截取的开始位置以及截取的字符串长度等参数,Substrin ...
- [SOLVED] “Error 1067: The process terminated unexpectedly” on Windows 10, 7 & 8
Windows background services enable Windows features function properly. If some errors happen to serv ...
- nginx 高并发配置参数
一.一般来说nginx 配置文件中对优化比较有作用的为以下几项: 1. worker_processes 8; nginx 进程数,建议按照cpu 数目来指定,一般为它的倍数 (如,2个四核的cpu ...
- MySQL Index--CREATE INDEX在各版本的优化
FIC(Fast index creation)特性在MySQL 5.5版本中引入FIC(Fast index creation)特性,创建索引时无需再拷贝整表数据,以提升索引的创建速度. FCI 操 ...
- 微信小程序 wxml 中使用 js函数
原文链接 1.在 utils 目录下 新建`filter.wxs` var filters = { toFix: function (value) { return value.toFixed(2) ...
- c++第五次作业
运算符重载 一.运算符重载基本规则 1.运算符重载是对已有的运算符赋予多重含义,使同一个运算符作用于不同类型的数据时导致不同的行为. 2.一般来讲,重载的功能应当与原有功能相似,不能改变原运算符的操作 ...
- windows server自动化发布——技术积累与整理
文章:应用在Windows系统中的自动化部署实践 博主大概讲解了一遍如何摸索实现自动化部署.不过内容不详细,很多具体细节需要自己摸索. 标题:windows server 部署服务(WDS) 地址:h ...
- unittest单元测试框架前言
一.在我们没有学习过python语言的时候领导让我们做接口测试 我们都使用工具来做测试,一般常用的如jemeter,postman这些个工具,我来推荐使用postman 这个工具来进行接口测试,有的小 ...