Snacks

Time Limit:5000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u

Submit Status

Description

百度科技园内有n个零食机,零食机之间通过n−1条路相互连通。每个零食机都有一个值v,表示为小度熊提供零食的价值。

由于零食被频繁的消耗和补充,零食机的价值v会时常发生变化。小度熊只能从编号为0的零食机出发,并且每个零食机至多经过一次。另外,小度熊会对某个零食机的零食有所偏爱,要求路线上必须有那个零食机。

为小度熊规划一个路线,使得路线上的价值总和最大。 

Input

输入数据第一行是一个整数T(T≤10),表示有T组测试数据。

对于每组数据,包含两个整数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

对于每组数据,首先输出一行”Case #?:”,在问号处应填入当前数据的组数,组数从1开始计算。

对于每次询问,输出从编号为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序)的更多相关文章

  1. Tsinsen A1505. 树(张闻涛) 倍增LCA,可持久化线段树,DFS序

    题目:http://www.tsinsen.com/A1505 A1505. 树(张闻涛) 时间限制:1.0s   内存限制:512.0MB    总提交次数:196   AC次数:65   平均分: ...

  2. BZOJ_3252_攻略_线段树+dfs序

    BZOJ_3252_攻略_线段树+dfs序 Description 题目简述:树版[k取方格数] 众所周知,桂木桂马是攻略之神,开启攻略之神模式后,他可以同时攻略k部游戏.今天他得到了一款新游戏< ...

  3. 【XSY2534】【BZOJ4817】树点涂色 LCT 倍增 线段树 dfs序

    题目大意 ​ Bob有一棵\(n\)个点的有根树,其中\(1\)号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同.定义一条路径的权值是:这条路径上的点(包括起点和终点)共有多少种不同的颜 ...

  4. 【bzoj4817】树点涂色 LCT+线段树+dfs序

    Description Bob有一棵n个点的有根树,其中1号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同.定义一条路 径的权值是:这条路径上的点(包括起点和终点)共有多少种不同的颜色. ...

  5. S - Query on a tree HDU - 3804 线段树+dfs序

    S - Query on a tree HDU - 3804   离散化+权值线段树 题目大意:给你一棵树,让你求这棵树上询问的点到根节点直接最大小于等于val的长度. 这个题目和之前写的那个给你一棵 ...

  6. HDU 5692 线段树+dfs序

    Snacks Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  7. 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序

    3779: 重组病毒 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 224  Solved: 95[Submit][Status][Discuss] ...

  8. 【BZOJ-3306】树 线段树 + DFS序

    3306: 树 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 792  Solved: 262[Submit][Status][Discuss] De ...

  9. Codeforces 343D WaterTree - 线段树, DFS序

    Description Translated by @Nishikino_Maki from Luogu 行吧是我翻的 Mad scientist Mike has constructed a roo ...

随机推荐

  1. Linux下VNC配置多个桌面和修改密码 不会当系统重启vnc失效

    1:vncserver 2:iptables -I INPUT -p tcp --dport 5901 -j ACCEPT   客户端方式 3:iptables -I INPUT -p tcp --d ...

  2. Js中数据类型判断的几种方法

    判断js中的数据类型有一下几种方法:typeof.instanceof. constructor. prototype. $.type()/jquery.type(),接下来主要比较一下这几种方法的异 ...

  3. ruby, gem install 出现网络错误

    gem sources #查看目前的源 gem sources --remove https://rubygems.org/ gem sources -a https://ruby.taobao.or ...

  4. w3c学习总结1

    1.根据 HTML5 规范,在没有其他合适标签更合适时,才应该把 <b> 标签作为最后的选项.HTML5 规范声明:应该使用 <h1> - <h6> 来表示标题,使 ...

  5. EF 报【序列包含一个以上的元素】解决办法

    1.检查模型是否存在重复的字段,eg: public class AggregateRoot { public System.Guid Guid { get; set; } } public part ...

  6. xcode 6 出现的新问题

    1.prefix.pch文件的使用 [1].需要自己创建 点击new file-->选择IOS中的Other选项卡,选择PCH File [2].创建完后需要设置一下才能成功 Prefix He ...

  7. HTML学习一(入门了解)

    基础部分---------------------------------一:简介HTML 是用来描述网页的一种语言.HTML 指的是超文本标记语言 (Hyper Text Markup Langua ...

  8. jquery 改变变量出现值不同步

    出现问题的代码 var unc = 0; $.get( 'index.php', 'data=1', function(res) { unc=1; } ); alert(nuc); 这样的话,不管aj ...

  9. STM8S STM8L引脚如何配置最低(转)

    源:STM8S STM8L引脚如何配置功耗最低 STM8S无任何外围电路 单片机CAP接104电容 复位接上拉电阻,其它引脚全部悬空,利用以下程序测试电流如下:(以前也用STM8L做过类似实验,情况也 ...

  10. cocos2d-x 定时器selector的使用 :schedule的使用

    在游戏设计时,我们需要不断的改变屏幕显示来反映游戏操作的效果,最简单的就是提示用户已经进行的游戏时间.为此,我们需要使用cocos2d-x内置的任务调度机制,即CCNode的schedule成员函数. ...