http://www.lydsy.com/JudgeOnline/problem.php?id=4034

树链剖分。

跟NOI2015的“软件包管理”一模一样。。。。。

河南的爽死了。。。。。。

#include<cstdio>
#include<cstdlib>
#include<iostream>
#include<fstream>
#include<algorithm>
#include<cstring>
#include<string>
#include<cmath>
#include<queue>
#include<stack>
#include<map>
#include<utility>
#include<set>
#include<bitset>
#include<vector>
#include<functional>
#include<deque>
#include<cctype>
#include<climits>
#include<complex>
//#include<bits/stdc++.h>适用于CF,UOJ,但不适用于poj using namespace std; typedef long long LL;
typedef double DB;
typedef pair<int,int> PII;
typedef complex<DB> CP; #define mmst(a,v) memset(a,v,sizeof(a))
#define mmcy(a,b) memcpy(a,b,sizeof(a))
#define fill(a,l,r,v) fill(a+l,a+r+1,v)
#define re(i,a,b) for(i=(a);i<=(b);i++)
#define red(i,a,b) for(i=(a);i>=(b);i--)
#define ire(i,x) for(typedef(x.begin()) i=x.begin();i!=x.end();i++)
#define fi first
#define se second
#define m_p(a,b) make_pair(a,b)
#define SF scanf
#define PF printf
#define two(k) (1<<(k)) template<class T>inline T sqr(T x){return x*x;}
template<class T>inline void upmin(T &t,T tmp){if(t>tmp)t=tmp;}
template<class T>inline void upmax(T &t,T tmp){if(t<tmp)t=tmp;} const DB EPS=1e-;
inline int sgn(DB x){if(abs(x)<EPS)return ;return(x>)?:-;}
const DB Pi=acos(-1.0); inline int gint()
{
int res=;bool neg=;char z;
for(z=getchar();z!=EOF && z!='-' && !isdigit(z);z=getchar());
if(z==EOF)return ;
if(z=='-'){neg=;z=getchar();}
for(;z!=EOF && isdigit(z);res=res*+z-'',z=getchar());
return (neg)?-res:res;
}
inline LL gll()
{
LL res=;bool neg=;char z;
for(z=getchar();z!=EOF && z!='-' && !isdigit(z);z=getchar());
if(z==EOF)return ;
if(z=='-'){neg=;z=getchar();}
for(;z!=EOF && isdigit(z);res=res*+z-'',z=getchar());
return (neg)?-res:res;
} const int maxN=; int N,Q;
int val[maxN+];
int now,first[maxN+];
struct Tedge{int v,next;}edge[*maxN+]; inline void addedge(int u,int v){now++;edge[now].v=v;edge[now].next=first[u];first[u]=now;} int head,tail,que[maxN+];
int fa[maxN+],size[maxN+],heavyson[maxN+],gao[maxN+];
int cnt,idx[maxN+],l[maxN+],r[maxN+];
int vis[maxN+],top,sta[maxN+],last[maxN+];
inline void build()
{
int i,j;
que[head=tail=]=;
while(head<=tail)
{
int u=que[head++],v;
for(i=first[u],v=edge[i].v;i!=-;i=edge[i].next,v=edge[i].v)if(v!=fa[u])fa[que[++tail]=v]=u;
}
red(j,tail,)
{
int u=que[j],v;
size[u]=;
for(i=first[u],v=edge[i].v;i!=-;i=edge[i].next,v=edge[i].v)if(v!=fa[u])size[u]+=size[v];
}
re(j,,tail)
{
int u=que[j],v,heavy=-;
for(i=first[u],v=edge[i].v;i!=-;i=edge[i].next,v=edge[i].v)if(v!=fa[u])
if(heavy==- || size[heavy]<size[v]) heavy=v;
heavyson[u]=heavy;
}
vis[sta[top=]=]=;
last[]=first[];
idx[]=++cnt;
gao[]=;
while(top>=)
{
int u=sta[top],i=last[u],v;
if(heavyson[u]!=- && !vis[heavyson[u]])
{
v=heavyson[u];
vis[sta[++top]=v]=;
last[v]=first[v];
idx[v]=++cnt;
gao[v]=gao[u];
}
else
for(v=edge[i].v;i!=-;i=edge[i].next,v=edge[i].v)if(v!=fa[u] && !vis[v])
{
vis[sta[++top]=v]=;
last[v]=first[v];
idx[v]=++cnt;
gao[v]=v;
last[u]=edge[i].next;
break;
}
if(i==-)top--;
}
red(j,tail,)
{
int u=que[j],v;
l[u]=r[u]=idx[u];
for(i=first[u],v=edge[i].v;i!=-;i=edge[i].next,v=edge[i].v)if(v!=fa[u])upmin(l[u],l[v]),upmax(r[u],r[v]);
}
} struct Ttree{LL v,add;}tr[*maxN+];
inline void down(int rt,int l,int r,int mid)
{
if(tr[rt].add==)return;
LL add=tr[rt].add;
tr[rt*].add+=add;tr[rt*].v+=add*LL(mid-l+);
tr[rt*+].add+=add;tr[rt*+].v+=add*LL(r-mid);
tr[rt].add=;
}
inline void update(int rt,int l,int r,int x,int y,LL val)
{
if(l>r || x>y || y<l || r<x)return;
if(x<=l && r<=y){tr[rt].add+=val;tr[rt].v+=val*LL(r-l+);return;}
int mid=(l+r)>>;
down(rt,l,r,mid);
update(rt*,l,mid,x,y,val);
update(rt*+,mid+,r,x,y,val);
tr[rt].v=tr[rt*].v+tr[rt*+].v;
}
inline LL ask(int rt,int l,int r,int x,int y)
{
if(l>r || x>y || y<l || r<x)return ;
if(x<=l && r<=y)return tr[rt].v;
int mid=(l+r)>>;
down(rt,l,r,mid);
return ask(rt*,l,mid,x,y)+ask(rt*+,mid+,r,x,y);
} inline LL query(int x)
{
LL res=;
while(x)
{
res+=ask(,,N,idx[gao[x]],idx[x]);
x=fa[gao[x]];
}
return res;
} int main()
{
freopen("bzoj4034.in","r",stdin);
freopen("bzoj4034.out","w",stdout);
int i;
N=gint();Q=gint();
re(i,,N)val[i]=gint();
now=-;mmst(first,-);
re(i,,N-){int u=gint(),v=gint();addedge(u,v);addedge(v,u);}
build();
re(i,,N)update(,,N,idx[i],idx[i],LL(val[i]));
while(Q--)
{
int type=gint(),x,a;
switch(type)
{
case :
x=gint();a=gint();
update(,,N,idx[x],idx[x],LL(a));
break;
case :
x=gint();a=gint();
update(,,N,l[x],r[x],LL(a));
break;
case :
x=gint();
//PF("%lld\n",query(x));
cout<<query(x)<<endl;
break;
}
}
return ;
}

bzoj4034的更多相关文章

  1. 【BZOJ4034】[HAOI2015]树上操作 树链剖分+线段树

    [BZOJ4034][HAOI2015]树上操作 Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 ...

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

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

  3. BZOJ4034 [HAOI2015]树上操作 树链剖分

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ4034 题意概括 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三 ...

  4. 【BZOJ4034】T2(树链剖分)

    题意: 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有点的点权都增 ...

  5. bzoj4034: [HAOI2015]T2

    4034: [HAOI2015]T2 Time Limit: 10 Sec  Memory Limit: 256 MB Submit: 2684  Solved: 843 Description 有一 ...

  6. 【bzoj4034】[HAOI2015]树上操作

    题目描述 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有点的点权都 ...

  7. BZOJ4034——[HAOI2015]T2

    1.题目大意:用一个数据结构支持树的点修改和子树修改.树上路径和 2.分析:树链剖分裸题 #include <cstdio> #include <cstdlib> #inclu ...

  8. BZOJ4034 T2

    Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所 ...

  9. [BZOJ4034] [HAOI2015] T2 (树链剖分)

    Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所 ...

随机推荐

  1. ios 限制输入长度

    ----------------UITextField限制输入的长度------------ - (BOOL)textField:(UITextField *)textField shouldChan ...

  2. java中paint repaint update 之间的关系

    最近总结了一下java中的paint,repaint和updata三者之间的关系,首先咱们都知道用paint方法来绘图,用repaint重绘,用update来写双缓冲.但是他们之间是怎么来调用的呢,咱 ...

  3. Java_XML操作

    xml的写: code: import java.io.File; import java.io.StringWriter; import javax.xml.parsers.DocumentBuil ...

  4. 获取程序中无需释放的ViewController

    AppDelegate.h @property (strong, nonatomic) UIViewController *viewController; 在需要用的地方 #define appDel ...

  5. [原创作品]Javascript内存管理机制

    如果你也喜欢分享,欢迎加入我们:QQ group:164858883 内存策略:堆内存和栈内存栈内存:在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配.当在一段代码块中定义一个 ...

  6. sql列转行

    1.需要实现一个单行的统计报表 思路先用一个union查出单列,然后再把单列转成单行 2.实现 SELECT MAX(CASE WHEN type = 1 THEN num ELSE 0 END) A ...

  7. Android获取屏幕分辨率及DisplayMetrics简介

    Android 可设置为随着窗口大小调整缩放比例,但即便如此,手机程序设计人员还是必须知道手机屏幕的边界,以避免缩放造成的布局变形问题. 手机的分辨率信息是手机的一项重要信息,很好的是,Android ...

  8. samba服务简介

    1.1 Samba 概述Samba主要用于Windows和Linux之间的文件共享,也一样用于Linux和Linux之间的共享文件:不过对于Linux和Linux之间共享文件有更好的网络文件系统NFS ...

  9. Asp.Net 下载文件的几种方式

    asp.net下载文件几种方式 protected void Button1_Click(object sender, EventArgs e) { /* 微软为Response对象提供了一个新的方法 ...

  10. C#构造函数使用

    作用:帮助我们初始化对像(给对像的每个属性依次的赋值) 构造函数是一个特殊的方法 1.构造函数没有返回值,连void也不能写 2.构造函数名称要和类名一样 3.创建对像时会执行构造函数 4.构造函数可 ...