BZOJ1180: [CROATIAN2009]OTOCI
一遍AC,开心!
$Link-Cut-Tree$最后一题
//BZOJ 1180 //by Cydiater //2016.9.18 #include <iostream> #include <cstdio> #include <cstring> #include <string> #include <algorithm> #include <queue> #include <map> #include <ctime> #include <cmath> #include <iomanip> #include <cstdlib> using namespace std; #define ll long long #define up(i,j,n) for(int i=j;i<=n;i++) #define down(i,j,n) for(int i=j;i>=n;i--) const int MAXN=1e6+5; const int oo=0x3f3f3f3f; inline int read(){ char ch=getchar();int x=0,f=1; while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();} while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();} return x*f; } int N,q[MAXN],top=0,M,nodea,nodeb,node,v; char op[15]; struct Tree{ int son[2],v,sum,tag,fa; }t[MAXN]; namespace solution{ inline bool get(int node){return t[t[node].fa].son[1]==node;} inline bool isroot(int node){return t[t[node].fa].son[0]!=node&&t[t[node].fa].son[1]!=node;} inline bool updata(int node){ if(node){ t[node].sum=t[node].v; if(t[node].son[0])t[node].sum+=t[t[node].son[0]].sum; if(t[node].son[1])t[node].sum+=t[t[node].son[1]].sum; } } inline void downit(int node){ if(t[node].tag){ t[t[node].son[0]].tag^=1;t[t[node].son[1]].tag^=1; swap(t[node].son[0],t[node].son[1]); t[node].tag^=1; } } inline void rotate(int node){ int old=t[node].fa,oldf=t[old].fa,which=get(node); if(!isroot(old))t[oldf].son[t[oldf].son[1]==old]=node; t[old].son[which]=t[node].son[which^1];t[t[old].son[which]].fa=old; t[node].son[which^1]=old;t[node].fa=oldf;t[old].fa=node; updata(old);updata(node); } inline void splay(int node){ top=0;q[++top]=node; for(int i=node;!isroot(i);i=t[i].fa)q[++top]=t[i].fa; down(i,top,1)downit(q[i]); while(!isroot(node)){ int old=t[node].fa,oldf=t[old].fa; if(!isroot(old))rotate(get(node)==get(old)?old:node); rotate(node); } } inline void access(int node){ int tmp=0; while(node){ splay(node);t[node].son[1]=tmp; updata(node);tmp=node; node=t[node].fa; } } inline void Reverse(int node){ access(node);splay(node);t[node].tag^=1; } inline void Link(int noda,int nodb){ Reverse(noda);t[noda].fa=nodb; } inline void Cut(int noda,int nodb){ Reverse(noda);access(nodb);splay(nodb); t[nodb].son[0]=t[noda].fa=0; } inline int find(int node){ access(node);splay(node); while(t[node].son[0])node=t[node].son[0]; return node; } inline void LCA(int noda,int nodb){ Reverse(nodb);access(noda);splay(noda); } inline void change(int node,int v){ access(node); splay(node); t[node].v=v;updata(node); } void init(){ N=read(); up(i,1,N){ t[i].v=t[i].sum=read(); t[i].son[0]=t[i].son[1]=t[i].fa=0; } } void slove(){ M=read(); while(M--){ scanf("%s",op); if(op[0]=='b'){ nodea=read();nodeb=read(); if(find(nodea)==find(nodeb))puts("no"); else{ puts("yes"); Link(nodea,nodeb); } } if(op[0]=='p'){ node=read();v=read(); change(node,v); } if(op[0]=='e'){ nodea=read();nodeb=read(); if(find(nodea)==find(nodeb)){ LCA(nodea,nodeb); printf("%d\n",t[nodea].sum); } else puts("impossible"); } } } } int main(){ //freopen("input.in","r",stdin); using namespace solution; init(); slove(); return 0; }
BZOJ1180: [CROATIAN2009]OTOCI的更多相关文章
- BZOJ1180 [CROATIAN2009]OTOCI LCT
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1180 本题和BZOJ2843一样. BZOJ2843 极地旅行社 LCT 题意概括 有n座岛 每座 ...
- BZOJ2843极地旅行社&BZOJ1180[CROATIAN2009]OTOCI——LCT
题目描述 给出n个结点以及每个点初始时对应的权值wi.起始时点与点之间没有连边.有3类操作: 1.bridge A B:询问结点A与结点B是否连通. 如果是则输出“no”.否则输出“yes”,并且在 ...
- BZOJ1180 [CROATIAN2009]OTOCI 【LCT】
题目 给出n个结点以及每个点初始时对应的权值wi.起始时点与点之间没有连边.有3类操作: 1.bridge A B:询问结点A与结点B是否连通.如果是则输出"no".否则输出&qu ...
- [bzoj1180][CROATIAN2009]OTOCI_LCT
OTOCI bzoj-1180 CROATIAN-2009 题目大意:给你n个离散的点,m个操作.支持:两点加边(保证还是森林),修改单点权值,询问两点是否联通,查询联通两点之间路径权值. 注释:$1 ...
- BZOJ 1180: [CROATIAN2009]OTOCI [LCT]
1180: [CROATIAN2009]OTOCI Time Limit: 50 Sec Memory Limit: 162 MBSubmit: 961 Solved: 594[Submit][S ...
- BZOJ 1180: [CROATIAN2009]OTOCI
1180: [CROATIAN2009]OTOCI Time Limit: 50 Sec Memory Limit: 162 MBSubmit: 989 Solved: 611[Submit][S ...
- 1180: [CROATIAN2009]OTOCI(LCT)
1180: [CROATIAN2009]OTOCI Time Limit: 50 Sec Memory Limit: 162 MBSubmit: 1200 Solved: 747[Submit][ ...
- 1180: [CROATIAN2009]OTOCI
1180: [CROATIAN2009]OTOCI Time Limit: 50 Sec Memory Limit: 162 MBSubmit: 1032 Solved: 638[Submit][ ...
- 【BZOJ1180】: [CROATIAN2009]OTOCI & 2843: 极地旅行社 LCT
竟然卡了我....忘记在push_down先下传父亲的信息了....还有splay里for():卡了我10min,但是双倍经验还是挺爽的,什么都不用改. 感觉做的全是模板题,太水啦,不能这么水了... ...
随机推荐
- versionCompare 版本号比较工具
简介 需求非常简单,需要比较软件或app的版本号,判断大小,形如 0.10.2形式的版本号字符串.实现逻辑是按照点(.)分割字符串,然后逐级比较版本大小.不存在的按0处理,空字符串小于非空字符串. 测 ...
- Stem函数绘图
stem(n,x,'filled');第三个参数是绘图的样式,filled就是填充,将圆圈填充. Stem函数绘图各种不同的绘图函数分别适用于不同的场合,使用“stem”绘制针状图最简单,从附录中提供 ...
- 37-more 简明笔记
分页显示文本 more [options] file more用于分页显示文本文件,最早出现在BSD当中,但这一命令非常基本,后来less命令对其做了增强,所谓的less也就是少即是多 参数 file ...
- [团队项目]Github生成燃尽图的方式
经过一晚上折腾,终于算是把linux上成功生成了我们团队项目的燃尽图,效果还是不错,在过程中又发现了另一种生成燃尽图的方式,也是基于一个开源项目. 1.准备: 首先你的项目一定要有milestone. ...
- Learning jQuery, 4th Edition 勘误表
来源于:http://book.learningjquery.com/3145/errata/ Chapter 1 page 14 The CSS snippet is correct, but it ...
- 最完整的Elasticsearch 基础教程
翻译:潘飞(tinylambda@gmail.com) 基础概念 Elasticsearch有几个核心概念.从一开始理解这些概念会对整个学习过程有莫大的帮助. 接近实时(NRT) Ela ...
- 简单解决ListView和ScrollView冲突,复杂情况仅供参考
ScrollView嵌套ListView冲突问题的最优解决方案 (转) 记录学习之用 项目做多了之后,会发现其实 ScrollView嵌套ListVew或者GridView等很常用,但是你也会发现各种 ...
- json:There is a cycle in the hierarchy!
在使用JSONObject.fromObject的时候,出现“There is a cycle in the hierarchy”异常. 意思是出现了死循环,也就是Model之间有循环包含关系: 解决 ...
- CAlayer层的属性
iOS开发UI篇—CAlayer层的属性 一.position和anchorPoint 1.简单介绍 CALayer有2个非常重要的属性:position和anchorPoint @property ...
- GameObject.Instantiate(游戏体的实例化),角色的选择
using UnityEngine; using System.Collections; public class CharacterCreation : MonoBehaviour { public ...