URAL 题目1553. Caves and Tunnels(Link Cut Tree 改动点权,求两点之间最大)
1553. Caves and Tunnels
Memory limit: 64 MB
one route between every pair of caves. But then scientists faced a particular problem. Sometimes in the caves faint explosions happen. They cause emission of radioactive isotopes and increase radiation level in the cave. Unfortunately robots don't stand radiation
well. But for the research purposes they must travel from one cave to another. So scientists placed sensors in every cave to monitor radiation level in the caves. And now every time they move robots they want to know the maximal radiation level the robot will
have to face during its relocation. So they asked you to write a program that will solve their problem.
Input
specifying the numbers of the caves connected by corresponding tunnel. The next line has an integer Q (Q ≤ 100000) representing the number of queries. The Q queries follow on a single line each. Every query has a form of "C U V",
where C is a single character and can be either 'I' or 'G' representing the type of the query (quotes for clarity only). In the case of an 'I' query radiation level in U-th cave (1 ≤ U ≤ N) is incremented by V (0 ≤ V ≤ 10000).
In the case of a 'G' query your program must output the maximal level of radiation on the way between caves with numbers U and V (1 ≤ U, V ≤ N) after all increases of radiation ('I' queries) specified before current
query. It is assumed that initially radiation level is 0 in all caves, and it never decreases with time (because isotopes' half-life time is much larger than the time of observations).
Output
Sample
input | output |
---|---|
|
|
Tags: data structures (
space=1&num=1553" style="color:gray">hide tags for unsolved problems
)
瞬秒~~
题目大意:一棵树,開始每一个点权的权值为0,后边q次操作。I a b,a点点权加b。G a b查询从a到b要走的最大的权值
ac代码
- #include<stdio.h>
- #include<string.h>
- #include<queue>
- #include<iostream>
- #define INF 0x7fffffff
- #define max(a,b) (a>b?a:b)
- using namespace std;
- int vis[100050];
- struct LCT
- {
- int bef[100050],pre[100050],next[100050][2],key[100050],val[100050];
- void init()
- {
- memset(pre,0,sizeof(pre));
- memset(next,0,sizeof(next));
- memset(key,0,sizeof(key));
- val[0]=-INF;
- }
- void pushup(int x)
- {
- val[x]=max(key[x],max(val[next[x][1]],val[next[x][0]]));
- }
- void rotate(int x,int kind)
- {
- int y,z;
- y=pre[x];
- z=pre[y];
- next[y][!kind]=next[x][kind];
- pre[next[x][kind]]=y;
- next[z][next[z][1]==y]=x;
- pre[x]=z;
- next[x][kind]=y;
- pre[y]=x;
- pushup(y);
- }
- void splay(int x)
- {
- int rt;
- for(rt=x;pre[rt];rt=pre[rt]);
- if(x!=rt)
- {
- bef[x]=bef[rt];
- bef[rt]=0;
- while(pre[x])
- {
- if(next[pre[x]][0]==x)
- {
- rotate(x,1);
- }
- else
- rotate(x,0);
- }
- pushup(x);
- }
- }
- void access(int x)
- {
- int fa;
- for(fa=0;x;x=bef[x])
- {
- splay(x);
- pre[next[x][1]]=0;
- bef[next[x][1]]=x;
- next[x][1]=fa;
- pre[fa]=x;
- bef[fa]=0;
- fa=x;
- pushup(x);
- }
- }
- void change(int x,int y)
- {
- key[x]+=y;
- splay(x);
- }
- int query(int x,int y)
- {
- access(y);
- for(y=0;x;x=bef[x])
- {
- splay(x);
- if(!bef[x])
- {
- return max(key[x],max(val[next[x][1]],val[y]));
- }
- pre[next[x][1]]=0;
- bef[next[x][1]]=x;
- next[x][1]=y;
- pre[y]=x;
- bef[y]=0;
- y=x;
- pushup(x);
- }
- return 0;
- }
- }lct;
- struct s
- {
- int u,v,next;
- }edge[200020<<1];
- int head[200020],cnt;
- void add(int u,int v)
- {
- edge[cnt].u=u;
- edge[cnt].v=v;
- edge[cnt].next=head[u];
- head[u]=cnt++;
- }
- void bfs(int u)
- {
- queue<int>q;
- memset(vis,0,sizeof(vis));
- vis[u]=1;
- q.push(u);
- while(!q.empty())
- {
- u=q.front();
- q.pop();
- for(int i=head[u];i!=-1;i=edge[i].next)
- {
- int v=edge[i].v;
- if(!vis[v])
- {
- lct.bef[v]=u;
- vis[v]=1;
- q.push(v);
- }
- }
- }
- }
- int main()
- {
- int n;
- while(scanf("%d",&n)!=EOF)
- {
- int i=1;
- memset(head,-1,sizeof(head));
- cnt=0;
- for(i=1;i<n;i++)
- {
- int u,v;
- scanf("%d%d",&u,&v);
- add(u,v);
- add(v,u);
- }
- int q;
- scanf("%d",&q);
- lct.init();
- bfs(1);
- while(q--)
- {
- char str[2];
- int u,v;
- scanf("%s%d%d",str,&u,&v);
- if(str[0]=='I')
- lct.change(u,v);
- else
- printf("%d\n",lct.query(u,v));
- }
- }
- }
URAL 题目1553. Caves and Tunnels(Link Cut Tree 改动点权,求两点之间最大)的更多相关文章
- FOJ题目Problem 2082 过路费 (link cut tree边权更新)
Problem 2082 过路费 Accept: 382 Submit: 1279 Time Limit: 1000 mSec Memory Limit : 32768 KB Proble ...
- Codeforces Round #339 (Div. 2) A. Link/Cut Tree 水题
A. Link/Cut Tree 题目连接: http://www.codeforces.com/contest/614/problem/A Description Programmer Rostis ...
- LCT总结——概念篇+洛谷P3690[模板]Link Cut Tree(动态树)(LCT,Splay)
为了优化体验(其实是强迫症),蒟蒻把总结拆成了两篇,方便不同学习阶段的Dalao们切换. LCT总结--应用篇戳这里 概念.性质简述 首先介绍一下链剖分的概念(感谢laofu的讲课) 链剖分,是指一类 ...
- Link Cut Tree学习笔记
从这里开始 动态树问题和Link Cut Tree 一些定义 access操作 换根操作 link和cut操作 时间复杂度证明 Link Cut Tree维护链上信息 Link Cut Tree维护子 ...
- [CodeForces - 614A] A - Link/Cut Tree
A - Link/Cut Tree Programmer Rostislav got seriously interested in the Link/Cut Tree data structure, ...
- Link Cut Tree 总结
Link-Cut-Tree Tags:数据结构 ##更好阅读体验:https://www.zybuluo.com/xzyxzy/note/1027479 一.概述 \(LCT\),动态树的一种,又可以 ...
- 【刷题】洛谷 P3690 【模板】Link Cut Tree (动态树)
题目背景 动态树 题目描述 给定n个点以及每个点的权值,要你处理接下来的m个操作.操作有4种.操作从0到3编号.点从1到n编号. 0:后接两个整数(x,y),代表询问从x到y的路径上的点的权值的xor ...
- 洛谷P3690 [模板] Link Cut Tree [LCT]
题目传送门 Link Cut Tree 题目背景 动态树 题目描述 给定n个点以及每个点的权值,要你处理接下来的m个操作.操作有4种.操作从0到3编号.点从1到n编号. 0:后接两个整数(x,y),代 ...
- 脑洞大开加偏执人格——可持久化treap版的Link Cut Tree
一直没有点动态树这个科技树,因为听说只能用Splay,用Treap的话多一个log.有一天脑洞大开,想到也许Treap也能从底向上Split.仔细思考了一下,发现翻转标记不好写,再仔细思考了一下,发现 ...
随机推荐
- vuex相关的知识
vue的核心是store,它可以看作是一个容器,它包含着应用中的状态state(state,mutations,actions,getters, modules).它中的存储是响应式的,当store中 ...
- H5 canvas pc 端米字格 写字板
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Jmeter中的参数化常用的几种方式
Jmeter中的参数化常用的几种方式,这里讲一下前两个方式,最后一个在csv参数化里已详细讲解. 1.用户参数 2.函数助手 3.CSV Data Set Config 一.用户参数 位置:添加-前 ...
- viewstate 与 session 区别
Session存在于服务器端可以跨页面.耗费服务器资源.ViewState载体是页面文件,消耗带宽. EG: viewstate是存储在客户端的隐藏信息,当服务器接受请求回传时可以将viewstate ...
- source collection list
1.Anaconda:http://www.cnblogs.com/xiaoming123abc/p/6970890.html https://conda.io/docs/help-support.h ...
- 【Pytorch】关于torch.matmul和torch.bmm的输出tensor数值不一致问题
发现 对于torch.matmul和torch.bmm,都能实现对于batch的矩阵乘法: a = torch.rand((2,3,10))b = torch.rand((2,2,10))### ma ...
- C++ 赋值运算符重载
类的定义 class Test{ int id; public: Test(int i): id(i){ cout << "obj_" << i <& ...
- LeetCode(53) Maximum Subarray
题目 Find the contiguous subarray within an array (containing at least one number) which has the large ...
- Springboot开启事务
参考资料: https://blog.csdn.net/message_lx/article/details/77584847
- centos相关
查看虚拟机里的Centos7的IP:ip addr或者ifconfig ---https://blog.csdn.net/dancheren/article/details/73611878 Cen ...