题意:

思路:分块

使用树状数组维护sum[i]的前缀和

使用主席树维护root到u的路径上点的编号出现的个数

每次操作如果是修改就加入队列

如果是询问,考虑块内操作对询问的影响,每次在x点加上y会使x到root的点sum都加上y

每根号n次操作就暴力重构一次,清空队列并求出新的sum[i]的前缀和

 var t:array[..]of record
l,r:longint;
s:int64;
end;
sum,bit:array[..]of int64;
stk:array[..,..]of longint;
head,vet,next,fa,a:array[..]of longint;
root:array[..]of longint;
n,m,x,y,i,j,top,tot,cnt,kuai,rt,op:longint;
ans,tmp:int64; procedure add(a,b:longint);
begin
inc(tot);
next[tot]:=head[a];
vet[tot]:=b;
head[a]:=tot;
end; procedure pushup(p:longint);
begin
t[p].s:=t[t[p].l].s+t[t[p].r].s;
end; procedure update(l,r,x:longint;var p:longint);
var mid:longint;
begin
inc(cnt); t[cnt]:=t[p];
p:=cnt; inc(t[p].s);
if l=r then exit;
mid:=(l+r)>>;
if x<=mid then update(l,mid,x,t[p].l)
else update(mid+,r,x,t[p].r);
pushup(p);
end; function query(l,r,x,y,p:longint):int64;
var mid:longint;
begin
if (l>=x)and(r<=y) then exit(t[p].s);
mid:=(l+r)>>;
query:=;
if x<=mid then query:=query+query(l,mid,x,y,t[p].l);
if y>mid then query:=query+query(mid+,r,x,y,t[p].r);
pushup(p);
end; procedure dfs1(u:longint);
var e,v:longint;
begin
root[u]:=root[fa[u]];
update(,n,u,root[u]);
e:=head[u];
while e<> do
begin
v:=vet[e];
if v<>fa[u] then
begin
fa[v]:=u;
dfs1(v);
end;
e:=next[e];
end;
end; procedure dfs2(u:longint);
var e,v:longint;
begin
sum[u]:=a[u];
e:=head[u];
while e<> do
begin
v:=vet[e];
if v<>fa[u] then
begin
dfs2(v);
sum[u]:=sum[u]+sum[v];
end;
e:=next[e];
end;
end; function lowbit(x:longint):longint;
begin
exit(x and (-x));
end; procedure addbit(x:longint;y:int64);
begin
while x<=n do
begin
bit[x]:=bit[x]+y;
x:=x+lowbit(x);
end;
end; function querybit(x,y:longint):int64;
var k:longint;
begin
k:=y;
querybit:=;
while k> do
begin
querybit:=querybit+bit[k];
k:=k-lowbit(k);
end;
k:=x-;
while k> do
begin
querybit:=querybit-bit[k];
k:=k-lowbit(k);
end;
end; procedure build;
var i:longint;
begin
for i:= to n do bit[i]:=;
for i:= to n do addbit(i,sum[i]);
end; begin
assign(input,'common.in'); reset(input);
assign(output,'common.out'); rewrite(output);
readln(n,m);
kuai:=;
for i:= to n do read(a[i]);
for i:= to n do
begin
readln(x,y);
if x= then rt:=y
else
begin
add(x,y);
add(y,x);
end;
end;
dfs1(rt);
fillchar(head,sizeof(head),);
tot:=;
for i:= to n do
if i<>rt then add(fa[i],i);
dfs2(rt);
build; for i:= to m do
begin
readln(op,x,y);
if op= then
begin
inc(top); stk[top,]:=x; stk[top,]:=y-a[x];
a[x]:=y;
end
else
begin
ans:=querybit(x,y);
for j:= to top do
begin
tmp:=query(,n,x,y,root[stk[j,]]);
ans:=ans+stk[j,]*tmp;
end;
writeln(ans);
end;
if i mod kuai= then
begin
top:=;
dfs2(rt);
build;
end;
end;
close(input);
close(output);
end.

【ZJOI2017 Round1练习&BZOJ4765】D1T3 普通计算姬(主席树,分块)的更多相关文章

  1. bzoj 4765: 普通计算姬 主席树+替罪羊树思想

    题目大意: 给定一棵\(n\)个节点的带权树有根树,设\(sum_p\)表示以点\(p\)为根的这棵子树中所有节点的权 计算姬支持下列两种操作: 给定两个整数\(u,v\),修改点\(u\)的权值为\ ...

  2. 【bzoj4765】普通计算姬(双重分块)

    题目传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4765 这道题已经攒了半年多了...因为懒,一直没去写...所以今天才把这道题写出来... ...

  3. BZOJ4766:文艺计算姬(矩阵树定理)

    Description "奋战三星期,造台计算机".小W响应号召,花了三星期造了台文艺计算姬.文艺计算姬比普通计算机有更多的艺术细胞. 普通计算机能计算一个带标号完全图的生成树个数 ...

  4. bzoj 4765 普通计算姬 dfs序 + 分块

    题目链接 Description "奋战三星期,造台计算机".小G响应号召,花了三小时造了台普通计算姬.普通计算姬比普通计算机要厉害一些.普通计算机能计算数列区间和,而普通计算姬能 ...

  5. [bzoj4766] 文艺计算姬 (矩阵树定理+二分图)

    传送门 Description "奋战三星期,造台计算机".小W响应号召,花了三星期造了台文艺计算姬.文艺计算姬比普通计算机有更多的艺 术细胞.普通计算机能计算一个带标号完全图的生 ...

  6. 【bzoj4765】 普通计算姬

    题意 给出一棵有根树,$n$个点每个都有一个点权.$m$组操作每次可以修改一个点权或者询问编号在区间$[l,r]$的点的子树权值和的和. Solution 我们对节点编号分块,每一块统计该块中的节点的 ...

  7. 【bzoj4765】普通计算姬

    一道奇奇怪怪的数据结构题? 把树线性化,然后分块维护吧. 为了加速,求和用树状数组维护每个块的值. #include<bits/stdc++.h> #define N 100010 #de ...

  8. BZOJ 4765 普通计算姬 dfs序+分块+树状数组+好题!!!

    真是道好题...感到灵魂的升华... 按dfs序建树状数组,拿前缀和去求解散块: 按点的标号分块,分成一个个区间,记录区间子树和 的 总和... 具体地,需要记录每个点u修改后,对每一个块i的贡献,记 ...

  9. bzoj 4766: 文艺计算姬 矩阵树定理

    题目: 给定一个一边点数为\(n\),另一边点数为\(m\),共有\(n*m\)条边的带标号完全二分图\(K_{n,m}\) 计算其生成树个数 \(n,m,p \leq 10^{18} ,p为模数\) ...

随机推荐

  1. 【转】Android Support Library详细介绍

    网上对Android Support Library中各个依赖包介绍的中文资料太少了,结合官方文档和有限的参考资料做了一次总结,有描述得不对的地方还请指正. 一.主工程.依赖包.jar包.androi ...

  2. 基于udp协议的套接字及udp协议粘包问题

    udp协议的套接字 udp协议传输  服务端和客户端没有建立连接一说. import socket # 总结一下基础工作流程:服务端生成套接字并绑定ip_port,进入数据传输循环,服务端接受客户端发 ...

  3. CF781A Andryusha and Colored Balloons

    题意: Andryusha goes through a park each day. The squares and paths between them look boring to Andryu ...

  4. Scala基础篇-05求值策略

    Scala的求值策略有2种: call by value call by name 如何区分? 例子: def bar(x:Int,y: => Int) = def loop(): Int=lo ...

  5. 第3章 接口与API设计 52条笔记

    第3章 接口与API设计 52条笔记 第15条: 用前缀避免命名空间冲突 Objective-C 没有其他语言那种内置的命名空间机制 .鉴于此,我们在起名时要设法避免潜在的命名冲突,否则很容易就重名了 ...

  6. nginx 访问localhost老是下载文件不能打开网页什么情况?

    nginx打开网页直接下载文件的问题 nginx sites-available文件里的default已经修改过root 路径了. 但是访问localhost的时候总是直接下载网页而不是打开网址 很奇 ...

  7. 十个 JDBC 的最佳实践

    JDBC是Java为多种关系型数据库提供的统一的访问接口,以下是我长期使用JDBC总结的十个最佳实践. 1. 使用PrearedStatement 任何一个使用过JDBC的Java程序员几乎都知道这个 ...

  8. 秒杀Sublime Text的微软开源代码编辑工具Visual Studio Code

    1. 下载链接: https://code.visualstudio.com/ 2. 秒开一个ASP.NET网站源码 3.编辑CSS颜色支持 4.Git支持 5.常用快捷键 Ctrl+Shift+P ...

  9. 聊天室(C++客户端+Pyhton服务器)2.基本功能添加

    根据之前的框架添加新的功能 登录 点击相关按钮 // 登录按钮的响应void CMainDialog::OnBnClickedLogin(){ // 1. 获取用户输入的数据 UpdateData(T ...

  10. mean shift博客推荐

    https://blog.csdn.net/maweifei/article/details/78766784 https://blog.csdn.net/gdfsg/article/details/ ...