我说我是不是完蛋了啊... ...昨天考试线段树写错,调了好久才调回来;今天做这道树链剖分辣鸡操作题,TM写错了4个地方!先是建树为了省常数打了一个build结果初值赋错了,然后又是线段树!getmax和getsum错的还不是一个地方!最后我发现update赋的不是dfn[x]而是x!再这样下去我是不是有一天连for循环都不会打了啊!!!

    好吧我是用Windows的Devcpp写的,丑了一点啊。

#include	<iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#define ls (x<<1)
#define rs (x<<1|1)
using namespace std;
const int N = 30010;
struct Node{int to,next;}E[N<<1];
int n,m,fa[N],top[N],val[N],T[N<<4],T2[N<<4],son[N],size[N],rec[N],dfn[N],tot,dep[N],num,head[N];
inline int gi()
{
int x=0,res=1;char ch=getchar();
while(ch<'0' || ch>'9'){if(ch=='-')res=-res;ch=getchar();}
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x*res;
}
inline void link(int u,int v)
{
E[++tot]=(Node){v,head[u]};head[u]=tot;
E[++tot]=(Node){u,head[v]};head[v]=tot;
}
inline void dfs1(int x,int fat)
{
dep[x]=dep[fat]+1;
fa[x]=fat;size[x]++;
for(int e=head[x];e;e=E[e].next)
{
if(E[e].to==fat)continue;
dfs1(E[e].to,x);size[x]+=size[E[e].to];
if(size[E[e].to]>size[son[x]])son[x]=E[e].to;
}
}
inline void dfs2(int x,int tp)
{
top[x]=tp;dfn[x]=++num;rec[num]=x;
if(!son[x])return;
dfs2(son[x],tp);
for(int e=head[x];e;e=E[e].next)
if(E[e].to!=fa[x]&&E[e].to!=son[x])
dfs2(E[e].to,E[e].to);
}
inline void build(int x,int l,int r)
{
if(l==r){T2[x]=T[x]=val[rec[l]];return;}
int mid=(l+r)>>1;
build(ls,l,mid);build(rs,mid+1,r);
T2[x]=T2[ls]+T2[rs];T[x]=max(T[ls],T[rs]);
}
inline int gc()
{
char ch=getchar();
while(ch<'A'||ch>'Z')ch=getchar();
if(ch=='C')return 1;if(ch=='Q')ch=getchar();
if(ch=='M')return 2;if(ch=='S')return 3;
}
inline void update(int x,int l,int r,int xp,int v)
{
if(l==r){T[x]=T2[x]=v;return;}
int mid=(l+r)>>1;
if(xp<=mid)update(ls,l,mid,xp,v);
else update(rs,mid+1,r,xp,v);
T2[x]=T2[ls]+T2[rs];T[x]=max(T[ls],T[rs]);
}
inline int getmax(int x,int l,int r,int xl,int xr)
{
if(xl<=l && r<=xr)return T[x];
int mid=(l+r)>>1;
if(xr<=mid)return getmax(ls,l,mid,xl,xr);
else if(xl>mid)return getmax(rs,mid+1,r,xl,xr);
return max(getmax(ls,l,mid,xl,mid),getmax(rs,mid+1,r,mid+1,xr));
}
inline int gmax(int u,int v)
{
int Ans=-N*N;
while(top[u]^top[v])
{
if(dep[top[u]]<dep[top[v]])swap(u,v);
Ans=max(Ans,getmax(1,1,n,dfn[top[u]],dfn[u]));
u=fa[top[u]];
}
if(dep[u]<dep[v])swap(u,v);
Ans=max(Ans,getmax(1,1,n,dfn[v],dfn[u]));
return Ans;
}
inline int getsum(int x,int l,int r,int xl,int xr)
{
if(xl<=l && r<=xr)return T2[x];
int mid=(l+r)>>1;
if(xr<=mid)return getsum(ls,l,mid,xl,xr);
else if(xl>mid)return getsum(rs,mid+1,r,xl,xr);
else return getsum(ls,l,mid,xl,mid)+getsum(rs,mid+1,r,mid+1,xr);
}
inline int gsum(int u,int v)
{
int Ans=0;
while(top[u]^top[v])
{
if(dep[top[u]]<dep[top[v]])swap(u,v);
Ans+=getsum(1,1,n,dfn[top[u]],dfn[u]);
u=fa[top[u]];
}
if(dep[u]<dep[v])swap(u,v);
Ans+=getsum(1,1,n,dfn[v],dfn[u]);
return Ans;
}
int main()
{
n=gi();
for(int i=1;i<n;++i)link(gi(),gi());
for(int i=1;i<=n;++i)val[i]=gi();
dfs1(1,1);dfs2(1,1);build(1,1,n);m=gi();
while(m--)
{
int type=gc(),x=gi(),y=gi();
switch(type)
{
case 1:{update(1,1,n,dfn[x],y);break;}
case 2:{printf("%d\n",gmax(x,y));break;}
case 3:{printf("%d\n",gsum(x,y));break;}
default:{break;}
}
}
}

  

BZOJ1036 (其实这只是一份板子)的更多相关文章

  1. LCA 笔记

    简述这几天的LCA 心得: LCA有两种做法:离线 or 在线 先学的离线: 原理博客很多. 我写得两道题,已经模板. HDU:http://acm.hdu.edu.cn/showproblem.ph ...

  2. Linux内核剖析(四)为arm内核构建源码树

    前面说到要做linux底层开发或者编写Linux的驱动,必须建立内核源码树,之前我们提到过在本机上构建源码树—-Linux内核剖析(三),其建立的源码树是针对i686平台的,但是我么嵌入式系统用的是a ...

  3. 2016级算法第一次练习赛-C.斐波那契进阶

    870 斐波那契进阶 题目链接:https://buaacoding.cn/problem/870/index 思路 通过读题就可以发现这不是一般的求斐波那契数列,所以用数组存下所有的答案是不现实的. ...

  4. petrozavodsk summer 2018 游记&&总结

    day0: 出发前训了一场比较水bapc2017保持手感(恢复信心),成功AK了,不过罚时略高.然后三人打车从紫金港到杭州东站,坐高铁到上海虹桥,再坐机场快线到浦东机场(傻乎乎的jsb帮爸爸付了钱,然 ...

  5. HNOI2004 郁闷的出纳员(Splay)

    郁闷的出纳员 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的 ...

  6. Data Center Maintenance CodeForces - 950E

    http://codeforces.com/contest/950/problem/E 贴一份板子 #include<cstdio> #include<vector> #inc ...

  7. CSPS2019谢幕记

    留坑待填. 开始填坑. Day -1 最后一场模拟题.T1花2h切掉,T2啥都不会,T3看出部分解法然后写了暴搜,教练没放子任务,得了45,然后就$rk3$了. 晚上疯狂写板子,1.5h写了8份板子. ...

  8. JSOI(联合省选)2021 划水记

    流水账. Day 0 18:10 去本部拿准考证,结果发现已经没有人了./ruo 敲了几份板子,很早就去睡觉了. Day 1 7:30 到 NFLS 拿到准考证,几乎没有人来.于是做起了政治作业. 然 ...

  9. splay好板子

    找到一份比较好的板子,链接https://blog.csdn.net/crazy_ac/article/details/8034190 #include<cstdio> #include& ...

随机推荐

  1. 关于Springboot整合mybatis启动的问题

    由于是刚pull下来的项目整体也不熟悉,然后项目无法正常启动,爆出的异常为: Invalid bound statement (not found) 这是由于创建的新模块mapper与扫描mapper ...

  2. Entity Framework——建模建库

    1数据库初始化策略选择 三种初始化策略: 1)CreateDatabaseIfNotExists:默认的策略.如果数据库不存在,那么就创建数据库.但是如果数据库已存在,而且实体发生了变化,就会出现异常 ...

  3. 机器学习算法 - 支持向量机SVM

    在上两节中,我们讲解了机器学习的决策树和k-近邻算法,本节我们讲解另外一种分类算法:支持向量机SVM. SVM是迄今为止最好使用的分类器之一,它可以不加修改即可直接使用,从而得到低错误率的结果. [案 ...

  4. ubuntu debain下好用的编辑器

    geany: 轻量级的IDE apt-get install geany 用来写shell脚本和python十分方便.特别写python脚本时,它有丰富的提示和自动补全功能.查看代码也很方便

  5. Java集合(1)一 集合框架

    目录 Java集合(1)一 集合框架 Java集合(2)一 ArrayList 与 LinkList Java集合(3)一 红黑树.TreeMap与TreeSet(上) java集合(4)一 红黑树. ...

  6. php中使用swoole实现头协议

    当需要有数据交互的时候,为了安全起见,双方会协商一个固定的头协议,这样必须实现其头协议才能拿到数据. PHP的swoole完美的提供了固定包头+包体协议自动分包. 首先需要通过open_length_ ...

  7. 【MySQL疑难杂症】如何将树形结构存储在数据库中(方案一、Adjacency List)

    今天来看看一个比较头疼的问题,如何在数据库中存储树形结构呢? 像mysql这样的关系型数据库,比较适合存储一些类似表格的扁平化数据,但是遇到像树形结构这样有深度的人,就很难驾驭了. 举个栗子:现在有一 ...

  8. HDU 1014 Uniform Generator 欧几里得

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1014 解题思路: 1. 把题目意思读懂后,明白会输入两个数,然后根据题中的公式产生一系列伪随机数,看这 ...

  9. VS2015 密钥key

    亲测可用: HMGNV-WCYXV-X7G9W-YCX63-B98R2

  10. js作用域与执行环境(前端基础系列)

    一.作用域(what?) 官方解释是:"一段程序代码中所用到的名字并不总是有效/可用的,而限定这个名字的可用性的代码范围就是这个名字的作用域." 单从文字理解比较难懂,举个栗子: ...