HDU5692(线段树+dfs序)
Snacks
Description
由于零食被频繁的消耗和补充,零食机的价值v会时常发生变化。小度熊只能从编号为0的零食机出发,并且每个零食机至多经过一次。另外,小度熊会对某个零食机的零食有所偏爱,要求路线上必须有那个零食机。
为小度熊规划一个路线,使得路线上的价值总和最大。
Input
对于每组数据,包含两个整数n,m(1≤n,m≤100000),表示有n个零食机,m次操作。
接下来n−1行,每行两个整数x和y(0≤x,y<n),表示编号为x的零食机与编号为y的零食机相连。
接下来一行由n个数组成,表示从编号为0到编号为n−1的零食机的初始价值v(|v|<100000)。
接下来m行,有两种操作:0 x y,表示编号为x的零食机的价值变为y;1 x,表示询问从编号为0的零食机出发,必须经过编号为x零食机的路线中,价值总和的最大值。
本题可能栈溢出,辛苦同学们提交语言选择c++,并在代码的第一行加上:
`#pragma comment(linker, "/STACK:1024000000,1024000000") `
Output
对于每次询问,输出从编号为0的零食机出发,必须经过编号为x零食机的路线中,价值总和的最大值。
Sample Input
1
6 5
0 1
1 2
0 3
3 4
5 3
7 -5 100 20 -5 -7
1 1
1 3
0 2 -1
1 1
1 5
Sample Output
Case #1:
102
27
2
20 线段树+dfs序
//2016.8.11
#pragma comment(linker, "/STACK:1024000000, 1024000000")
#include<iostream>
#include<cstdio>
#include<vector>
#include<algorithm>
#define N 100005
#define lson (id<<1)
#define rson ((id<<1)|1)
#define mid ((l+r)>>1) using namespace std; struct node
{
long long max, lazy;
}tree[N*]; vector<int> v[N];
long long w[N], val[N];//val[i]表示从根节点走到i节点的价值和
int in[N], out[N], flag;//in记录查询区间的左端,out记录查询区间的右端 //线段树模板
//************************************************************************************
void push_up(int id)
{
tree[id].max = max(tree[lson].max, tree[rson].max);
return;
} void build_tree(int id, int l, int r)
{
if(l == r)
{
tree[id].max = val[l];
tree[id].lazy = ;
return ;
}
build_tree(lson, l, mid);
build_tree(rson, mid+, r);
push_up(id);
tree[id].lazy = ;
return ;
} void push_down(int id, int l, int r)
{
if(tree[id].lazy)
{
tree[lson].lazy += tree[id].lazy;
tree[rson].lazy += tree[id].lazy;
tree[lson].max += tree[id].lazy;
tree[rson].max += tree[id].lazy;
tree[id].lazy = ;
}
return ;
} void ins(int id, int l, int r, int ql, int qr, int tt)
{
if(ql<=l&&r<=qr)
{
tree[id].max += tt;
tree[id].lazy += tt;
return;
}
if(tree[id].lazy) push_down(id, l, r);
if(ql<=mid)
ins(lson, l, mid, ql, qr, tt);
if(mid+<=qr)
ins(rson, mid+, r, ql, qr, tt);
push_up(id);
return;
} long long query(int id, int l, int r, int ql, int qr)
{
if(ql<=l && r<=qr)
{
return tree[id].max;
}
if(tree[id].lazy)
push_down(id, l, r);
long long maxnum = -;
if(ql<=mid) maxnum = max(maxnum, query(lson, l, mid, ql, qr));
if(mid+<=qr) maxnum = max(maxnum, query(rson, mid+, r, ql, qr));
return maxnum;
}
//************************************************************************************ void dfs(int a, int fa, long long wight)
{
in[a] = ++flag;
for(int i = ; i < v[a].size(); i++)
{
int b = v[a][i];
if(b==fa)continue;
dfs(b, a, w[b]+wight);
}
out[a] = flag;
val[in[a]] = wight;
} int main()
{
int T, n, m, a, b, cmd;
cin>>T;
for(int kase = ; kase <= T; kase++)
{
printf("Case #%d:\n", kase);
cin>>n>>m;
for(int i = ; i < N; i++)
v[i].clear();
for(int i = ; i < n-; i++)
{
scanf("%d%d", &a, &b);
a++; b++;
v[a].push_back(b);
v[b].push_back(a);
}
for(int i = ; i <= n; i++)
scanf("%lld", &w[i]);
flag = ;
dfs(, , w[]);
for(int i = ; i <= n; i++)
cout<<in[i]<<" "<<out[i]<<endl;
build_tree(, , n);
while(m--)
{
scanf("%d", &cmd);
if(cmd == )
{
scanf("%d%d", &a, &b);a++;
ins(, , n, in[a], out[a], b-w[a]);
w[a] = b;
}else
{
scanf("%d", &a); a++;
long long ans = query(, , n, in[a], out[a]);
cout<<ans<<endl;
}
}
} return ;
}
HDU5692(线段树+dfs序)的更多相关文章
- Tsinsen A1505. 树(张闻涛) 倍增LCA,可持久化线段树,DFS序
题目:http://www.tsinsen.com/A1505 A1505. 树(张闻涛) 时间限制:1.0s 内存限制:512.0MB 总提交次数:196 AC次数:65 平均分: ...
- BZOJ_3252_攻略_线段树+dfs序
BZOJ_3252_攻略_线段树+dfs序 Description 题目简述:树版[k取方格数] 众所周知,桂木桂马是攻略之神,开启攻略之神模式后,他可以同时攻略k部游戏.今天他得到了一款新游戏< ...
- 【XSY2534】【BZOJ4817】树点涂色 LCT 倍增 线段树 dfs序
题目大意 Bob有一棵\(n\)个点的有根树,其中\(1\)号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同.定义一条路径的权值是:这条路径上的点(包括起点和终点)共有多少种不同的颜 ...
- 【bzoj4817】树点涂色 LCT+线段树+dfs序
Description Bob有一棵n个点的有根树,其中1号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同.定义一条路 径的权值是:这条路径上的点(包括起点和终点)共有多少种不同的颜色. ...
- S - Query on a tree HDU - 3804 线段树+dfs序
S - Query on a tree HDU - 3804 离散化+权值线段树 题目大意:给你一棵树,让你求这棵树上询问的点到根节点直接最大小于等于val的长度. 这个题目和之前写的那个给你一棵 ...
- HDU 5692 线段树+dfs序
Snacks Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Sub ...
- 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序
3779: 重组病毒 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 224 Solved: 95[Submit][Status][Discuss] ...
- 【BZOJ-3306】树 线段树 + DFS序
3306: 树 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 792 Solved: 262[Submit][Status][Discuss] De ...
- Codeforces 343D WaterTree - 线段树, DFS序
Description Translated by @Nishikino_Maki from Luogu 行吧是我翻的 Mad scientist Mike has constructed a roo ...
随机推荐
- 过实现鹰眼图这个功能来进一步学习MapControl控件
我们通过实现鹰眼图这个功能来进一步学习MapControl控件.在实现鹰眼图之前,我们需 要接口有更深入的了解. 变主动为被动-出接口(OutBound interface) COM编程类似客户端和服 ...
- PAT (Advanced Level) 1080. Graduate Admission (30)
简单题. #include<cstdio> #include<cstring> #include<cmath> #include<vector> #in ...
- Unity3d/2d手机游戏开发第二版 (金玺曾) 随书资源
http://pan.baidu.com/s/1c0xpn4s Unity3d2d手机游戏开发配书资源文件.rar 1.36G 书上的链接坏掉了,我在论坛上面买了一份,放这分享给买了书找不到资源的同学 ...
- vim vimgdb reg 编译安装
在各种无法忍受下,还是决心自己编译安装一个vim.由于vimgdb for 7.3的patch一直有点问题,因此还是选择了vim7.2做为编译安装的版本.(1)获取vim7.2: http://www ...
- NMEA协议 上位机 C# (转)
源:NMEA协议 上位机 c# 前些时间写做了两款用NMEA协议的上位机,在这里做一个总结和记录.和大家分享,也为了以后不会忘记. NMEA协议总体来说,相对简单,是气象上比较成熟的协议. 主要有以下 ...
- c++ builder 2009如何生成独立运行exe(转)
参考资料:https://forums.codegear.com/thread.jspa?threadID=13559&tstart=703 查了很多网站资料,说得差不多,但是最后编译出来的还 ...
- CSS十问
CSS十问——好奇心+刨根问底=CSSer 最近有时间,想把酝酿的几篇博客都写出来,今天前端小学生带着10个问题,跟大家分享一下学习CSS的一些体会,我觉得想学好CSS,必须保持一颗好奇心和刨根问 ...
- UVa 594 - One Little, Two Little, Three Little Endians
题目大意:大小端模式的转换.所谓的小端模式,是指数据的高位保存在内存的高地址中,而数据的低位保存在内存的低地址中.与此相对,所谓的大端模式,是指数据的高位,保存在内存的低地址中,而数据的低位,保存在内 ...
- keystore 介绍
Keytool 是一个有效的安全钥匙和证书的管理工具. Java 中的 keytool.exe (位于 JDK\Bin 目录下)可以用来创建数字证书,所有的数字证书是以一条一条(采用别名区别)的形式存 ...
- java系列--重载和覆盖小结
继承中属性的隐藏和方法的覆盖 java中规定,子类用于隐藏的变量可以和父类的访问权限不同,如果访问权限被改变,则以子类的权限为准 java中允许子类的变量与父类变量的类型完全不同, ...