bzoj 4034: [HAOI2015]T2
4034: [HAOI2015]T2
Description
有一棵点数为 N 的树,以点 1 为根,且树点有边权。然后有 M 个
Input
第一行包含两个整数 N, M 。表示点数和操作数。
接下来一行 N 个整数,表示树中节点的初始权值。
Output
对于每个询问操作,输出该询问的答案。答案之间用换行隔开。
Sample Input
1 2 3 4 5
1 2
1 4
2 3
2 5
3 3
1 2 1
3 5
2 1 2
3 3
Sample Output
9
13
HINT
对于 100% 的数据, N,M<=100000 ,且所有输入数据的绝对值都不
Source
题解:
树链剖分模板题。
刚学树剖,贴个模板吧。。
#include<stdio.h>
#include<iostream>
using namespace std;
const int N=30005;
#define p1 (p<<1)
#define p2 (p<<1|1)
char c[5];
int Q,n,i,x,y,k,id[N],fa[N],top[N],dep[N],s[N],t[N<<2],T[N<<2];
int tot,head[N],to[N<<1],Next[N<<1];
inline void read(int &v){
char ch,fu=0;
for(ch='*'; (ch<'0'||ch>'9')&&ch!='-'; ch=getchar());
if(ch=='-') fu=1, ch=getchar();
for(v=0; ch>='0'&&ch<='9'; ch=getchar()) v=v*10+ch-'0';
if(fu) v=-v;
}
void add(int x,int y)
{
to[tot]=y;
Next[tot]=head[x];
head[x]=tot++;
}
inline void dfs(int x,int pre)
{
s[x]=1;
for(int i=head[x];i!=-1;i=Next[i])
if(to[i]!=pre)
{
dep[to[i]]=dep[x]+1;
fa[to[i]]=x;
dfs(to[i],x);
s[x]+=s[to[i]];
}
}
inline void Dfs(int x,int v)
{
id[x]=++k;
top[x]=v;
int son=0,i;
for(i=head[x];i!=-1;i=Next[i])
if(dep[to[i]]>dep[x]&&s[to[i]]>s[son]) son=to[i];
if(!son) return;
Dfs(son,v);
for(i=head[x];i!=-1;i=Next[i])
if(dep[to[i]]>dep[x]&&to[i]!=son) Dfs(to[i],to[i]);
}
void update(int l,int r,int x,int y,int p)
{
if(l==r)
{
t[p]=T[p]=y;
return;
}
int mid=(l+r)>>1;
if(x<=mid) update(l,mid,x,y,p1);else update(mid+1,r,x,y,p2);
t[p]=max(t[p1],t[p2]);
T[p]=T[p1]+T[p2];
}
int Max(int l,int r,int x,int y,int p)
{
if(x<=l&&r<=y) return t[p];
int mid=(l+r)>>1,ans=-1e9;
if(x<=mid) ans=Max(l,mid,x,y,p1);
if(y>mid) ans=max(ans,Max(mid+1,r,x,y,p2));
return ans;
}
int Sum(int l,int r,int x,int y,int p)
{
if(x<=l&&r<=y) return T[p];
int mid=(l+r)>>1,ans=0;
if(x<=mid) ans=Sum(l,mid,x,y,p1);
if(y>mid) ans+=Sum(mid+1,r,x,y,p2);
return ans;
}
int solvemax(int x,int y)
{
int ans=-1e9;
while(top[x]!=top[y])
{
if(dep[top[x]]<dep[top[y]]) swap(x,y);
ans=max(ans,Max(1,n,id[top[x]],id[x],1));
x=fa[top[x]];
}
if(id[x]>id[y]) swap(x,y);
ans=max(ans,Max(1,n,id[x],id[y],1));
return ans;
}
int solvesum(int x,int y)
{
int ans=0;
while(top[x]!=top[y])
{
if(dep[top[x]]<dep[top[y]]) swap(x,y);
ans+=Sum(1,n,id[top[x]],id[x],1);
x=fa[top[x]];
}
if(id[x]>id[y]) swap(x,y);
ans+=Sum(1,n,id[x],id[y],1);
return ans;
}
int main()
{
read(n);
for(i=1;i<=n;i++) head[i]=-1;
for(i=1;i<=n<<2;i++) t[i]=-1e9;
for(i=1;i<n;i++)
{
read(x),read(y);
add(x,y);
add(y,x);
}
dfs(1,0);
Dfs(1,1);
for(i=1;i<=n;i++)
{
read(x);
update(1,n,id[i],x,1);
}
read(Q);
while(Q--)
{
scanf("%s",c);read(x),read(y);
if(c[1]=='M') printf("%d\n",solvemax(x,y));else
if(c[1]=='S') printf("%d\n",solvesum(x,y));else
update(1,n,id[x],y,1);
}
return 0;
}
bzoj 4034: [HAOI2015]T2的更多相关文章
- bzoj 4034 [HAOI2015] T2(树链剖分,线段树)
4034: [HAOI2015]T2 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1536 Solved: 508[Submit][Status] ...
- Bzoj 4034: [HAOI2015]T2 树链剖分,子树问题,dfs序
4034: [HAOI2015]T2 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1841 Solved: 598[Submit][Status] ...
- BZOJ 4034: [HAOI2015]T2( 树链剖分 )
树链剖分...子树的树链剖分序必定是一段区间 , 先记录一下就好了 ------------------------------------------------------------------ ...
- 数据结构(树链剖分):BZOJ 4034: [HAOI2015]T2
Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中 ...
- BZOJ 4034 [HAOI2015]T2(树链剖分)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4034 [题目大意] 有一棵点数为 N 的树,以点 1 为根,且树点有边权. 有 M 个 ...
- BZOJ.4034 [HAOI2015]树上操作 ( 点权树链剖分 线段树 )
BZOJ.4034 [HAOI2015]树上操作 ( 点权树链剖分 线段树 ) 题意分析 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 ...
- bzoj 4034: [HAOI2015]树上操作 树链剖分+线段树
4034: [HAOI2015]树上操作 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 4352 Solved: 1387[Submit][Stat ...
- bzoj 4034: [HAOI2015]树上操作 (树剖+线段树 子树操作)
4034: [HAOI2015]树上操作 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 6779 Solved: 2275[Submit][Stat ...
- [BZOJ]4034: [HAOI2015]树上操作
[HAOI2015]树上操作 传送门 题目大意:三个操作 1:a,b,c b节点权值+c 2:a,b,c 以b为根的子树节点权值全部+c 3:a,b 查询b到根路径的权值和. 题解:树链剖分 操作1 ...
随机推荐
- arch安装完成之后不能使用笔记本自带的无线网卡
问题描述如下 我笔记本的wifi网卡识别不了,不知道为什么?? 使用ifconfig -a 只列出了有线网卡以及外接的无线网卡如下 enp4s0f1: flags=<UP,BROADCAST,M ...
- Perl6 必应抓取(1):测试版代码
一个相当丑漏的代码, 以后有时间再优化了. 默认所有查找都是15页, 如果结果没有15页这么多估计会有重复.速度还是很快的. sub MAIN() { my $fp = open 'bin_resul ...
- 36 - 网络编程-TCP编程
目录 1 概述 2 TCP/IP协议基础 3 TCP编程 3.1 通信流程 3.2 构建服务端 3.3 构建客户端 3.4 常用方法 3.4.1 makefile方法 3.5 socket交互 3.4 ...
- Spring源码解读Spring IOC原理
一.什么是Ioc/DI? IoC 容器:最主要是完成了完成对象的创建和依赖的管理注入等等. 先从我们自己设计这样一个视角来考虑: 所谓控制反转,就是把原先我们代码里面需要实现的对象创建.依赖的代码,反 ...
- hdu 4605 Magic Ball Game (在线主席树/离线树状数组)
版权声明:本文为博主原创文章,未经博主允许不得转载. hdu 4605 题意: 有一颗树,根节点为1,每一个节点要么有两个子节点,要么没有,每个节点都有一个权值wi .然后,有一个球,附带值x . 球 ...
- TypeError: not all arguments converted during string formatting
print ("So, you're 5r old, %r tall and %r heavy." % (age, height, weight)) print ("So ...
- centos7安装Python3的过程中会和Python2.7版本冲突导致yum版本比对应,致使yum不能使用的问题。
centos7安装Python3的过程中会和Python2.7版本冲突导致yum版本比对应,致使yum不能使用的问题. 原因:yum调用Python,启动程/usr/bin/yum就是一个python ...
- xshell 映射带跳板机服务器的端口到本地
1.配置xshell连接跳板机服务器: 2. 3.可用navicate等同过端口连接远程数据库.
- python-unittest学习2--生成报告
上个是小练习 ,这次将unittest模块化一下,也就是吧用例放在case目录下,start放在bin目录下面 -------------------start------------------- ...
- C# 获取计算机cpu,硬盘,内存相关的信息
using System;using System.Management; namespace MmPS.Common.Helper{ /// <summary> /// 获取计算机相关的 ...