题目传送门:1036: [ZJOI2008]树的统计Count

  这道题是我第一次打树剖的板子,虽然代码有点长,但是“打起来很爽”,而且整道题只花了不到1.5h+,还是一遍过样例!一次提交AC!(难道前天膜cyc神犇真的起作用了?)

  按捺不住激动的心情!!!

  这道题是树剖+线段树模板题,树剖把树转化成线段后就可以单点修改+区间求和/区间求max了。

  又臭又长的93行代码:

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
struct point{
int sum,max;
}a[];
int fir[],to[],ne[];
int vis[],fa[],dep[],size[],hson[],top[],id[];
int tot,n,m,q;
char s[];
void change(int now,int l,int r,int x,int k)
{
if(l==r)a[now].sum=a[now].max=k;
else{
int mid=(l+r)>>;
if(x<=mid)change(now<<,l,mid,x,k);else change(now<<|,mid+,r,x,k);
a[now].sum=a[now<<].sum+a[now<<|].sum; a[now].max=max(a[now<<].max,a[now<<|].max);
}
}
int getsum(int now,int l,int r,int x,int y)
{
if(x<=l&&r<=y)return a[now].sum;
else{
int mid=(l+r)>>,sum=;
if(x<=mid)sum+=getsum(now<<,l,mid,x,y);
if(mid<y)sum+=getsum(now<<|,mid+,r,x,y);
return sum;
}
}
int getmax(int now,int l,int r,int x,int y)
{
if(x<=l&&r<=y)return a[now].max;
else{
int mid=(l+r)>>,mx=-<<;
if(x<=mid)mx=max(mx,getmax(now<<,l,mid,x,y));
if(mid<y)mx=max(mx,getmax(now<<|,mid+,r,x,y));
return mx;
}
}
void add(int x,int y){to[++tot]=y; ne[tot]=fir[x]; fir[x]=tot;}
void dfs1(int now,int d)
{
int i,mxson=; size[now]=; vis[now]=; dep[now]=d;
for(i=fir[now];i;i=ne[i])
if(!vis[to[i]]){
fa[to[i]]=now; dfs1(to[i],d+);
if(size[to[i]]>mxson)mxson=size[to[i]],hson[now]=to[i];
size[now]+=size[to[i]];
}
}
void dfs2(int now,int tp)
{
int i;
top[now]=tp; id[now]=++tot;
if(hson[now])dfs2(hson[now],tp);
for(i=fir[now];i;i=ne[i])
if(to[i]!=hson[now]&&to[i]!=fa[now])dfs2(to[i],to[i]);
}
int main()
{
int i,x,y;
scanf("%d",&n); tot=;
for(i=;i<n;i++)scanf("%d%d",&x,&y),add(x,y),add(y,x);
for(i=;i<=n;i++)vis[i]=; tot=;
dfs1(,); dfs2(,);
for(i=;i<=n;i++)scanf("%d",&x),change(,,n,id[i],x);
scanf("%d",&q);
for(i=;i<=q;i++){
scanf("%s%d%d",s,&x,&y);
if(s[]=='C')change(,,n,id[x],y);
else if(s[]=='M'){
int mx=-<<;
while(top[x]!=top[y]){
if(dep[top[x]]<dep[top[y]]){int tmp=x; x=y; y=tmp;}
mx=max(mx,getmax(,,n,id[top[x]],id[x])); x=fa[top[x]];
}
if(dep[x]>dep[y]){int tmp=x; x=y; y=tmp;}
printf("%d\n",max(mx,getmax(,,n,id[x],id[y])));
}
else{
int sum=;
while(top[x]!=top[y]){
if(dep[top[x]]<dep[top[y]]){int tmp=x; x=y; y=tmp;}
sum+=getsum(,,n,id[top[x]],id[x]); x=fa[top[x]];
}
if(dep[x]>dep[y]){int tmp=x; x=y; y=tmp;}
printf("%d\n",sum+getsum(,,n,id[x],id[y]));
}
}
}

树链剖分+线段树

【bzoj1036】树的统计[ZJOI2008]树链剖分+线段树的更多相关文章

  1. BZOJ.1036 [ZJOI2008]树的统计Count ( 点权树链剖分 线段树维护和与最值)

    BZOJ.1036 [ZJOI2008]树的统计Count (树链剖分 线段树维护和与最值) 题意分析 (题目图片来自于 这里) 第一道树链剖分的题目,谈一下自己的理解. 树链剖分能解决的问题是,题目 ...

  2. 【BZOJ-2325】道馆之战 树链剖分 + 线段树

    2325: [ZJOI2011]道馆之战 Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 1153  Solved: 421[Submit][Statu ...

  3. 【BZOJ2243】[SDOI2011]染色 树链剖分+线段树

    [BZOJ2243][SDOI2011]染色 Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的 ...

  4. BZOJ2243 (树链剖分+线段树)

    Problem 染色(BZOJ2243) 题目大意 给定一颗树,每个节点上有一种颜色. 要求支持两种操作: 操作1:将a->b上所有点染成一种颜色. 操作2:询问a->b上的颜色段数量. ...

  5. POJ3237 (树链剖分+线段树)

    Problem Tree (POJ3237) 题目大意 给定一颗树,有边权. 要求支持三种操作: 操作一:更改某条边的权值. 操作二:将某条路径上的边权取反. 操作三:询问某条路径上的最大权值. 解题 ...

  6. bzoj4034 (树链剖分+线段树)

    Problem T2 (bzoj4034 HAOI2015) 题目大意 给定一颗树,1为根节点,要求支持三种操作. 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子 ...

  7. HDU4897 (树链剖分+线段树)

    Problem Little Devil I (HDU4897) 题目大意 给定一棵树,每条边的颜色为黑或白,起始时均为白. 支持3种操作: 操作1:将a->b的路径中的所有边的颜色翻转. 操作 ...

  8. Aizu 2450 Do use segment tree 树链剖分+线段树

    Do use segment tree Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.bnuoj.com/v3/problem_show ...

  9. 【POJ3237】Tree(树链剖分+线段树)

    Description You are given a tree with N nodes. The tree’s nodes are numbered 1 through N and its edg ...

随机推荐

  1. sql 注入安全过滤-安全模块

    <?php /** * 安全模块 * Email:zhangyuan@tieyou.com * 主要针对xss跨站攻击.sql注入等敏感字符串进行过滤 * @author hkshadow */ ...

  2. SpringAOP和AspectJ

    SpringAOP和AspectJ的关系 问题:之前对 SpringAOP和AspectJ的关系感到疑惑,因为曾经在书上看过SpringAOP集成了AspectJ,那么SpringAOP是直接使用了A ...

  3. Spring MVC的路径匹配

    Spring MVC中的路径匹配比起标准web.xml的servlet映射要灵活得多.路径匹配的默认策略是由org.springframework.util.AntPathMatcher实现的.顾名思 ...

  4. 《从零开始学Swift》学习笔记(Day 44)——重写属性

    原创文章,欢迎转载.转载请注明:关东升的博客 重写实例属性 我们可以在子类中重写从父类继承来的属性,属性有实例属性和静态属性之分,他们在具体实现也是不同的. 实例属性的重写一方面可以重写getter和 ...

  5. Python之可迭代对象、迭代器、生成器

    在使用Python的过程中,很容易混淆如下几个关联的概念: 1.容器(container) 2.可迭代对象(Iterable) 3.迭代器(Iterator) 4.生成器(generator) 5.生 ...

  6. 九度OJ 1360:乐透之猜数游戏 (递归)

    时间限制:2 秒 内存限制:32 兆 特殊判题:否 提交:955 解决:261 题目描述: 六一儿童节到了,YZ买了很多丰厚的礼品,准备奖励给JOBDU里辛劳的员工.为了增添一点趣味性,他还准备了一些 ...

  7. 学习 Tornado

    异步编程 预习 lambda Lambda functions can be used wherever function objects are required. They are syntact ...

  8. SqlCommand对象-Transaction事务的使用

    using (SqlConnection connection = new SqlConnection(connStr)) { SqlCommand sqlcmd = new SqlCommand() ...

  9. Struts之Token机制

    Struts的Token(令牌)机制能够很好的解决表单重复提交的问题,基本原理是:服务器端在处理到达的请求之前,会将请求中包含的令牌值与保存在当前用户会话中的令牌值进行比较,看是否匹配.在处理完该请求 ...

  10. [NOIP2018TG]旅行

    [NOIP2018TG]旅行 树很简单,对每个点sort儿子,贪心走就行了 基环树呢? 如果是1e5可能不太好做 但是5000的话枚举断边就可以\(n^2\)了 #include<bits/st ...