【ZJOI2017 Round1练习&BZOJ4765】D1T3 普通计算姬(主席树,分块)
题意:


思路:分块
使用树状数组维护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 普通计算姬(主席树,分块)的更多相关文章
- bzoj 4765: 普通计算姬 主席树+替罪羊树思想
题目大意: 给定一棵\(n\)个节点的带权树有根树,设\(sum_p\)表示以点\(p\)为根的这棵子树中所有节点的权 计算姬支持下列两种操作: 给定两个整数\(u,v\),修改点\(u\)的权值为\ ...
- 【bzoj4765】普通计算姬(双重分块)
题目传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4765 这道题已经攒了半年多了...因为懒,一直没去写...所以今天才把这道题写出来... ...
- BZOJ4766:文艺计算姬(矩阵树定理)
Description "奋战三星期,造台计算机".小W响应号召,花了三星期造了台文艺计算姬.文艺计算姬比普通计算机有更多的艺术细胞. 普通计算机能计算一个带标号完全图的生成树个数 ...
- bzoj 4765 普通计算姬 dfs序 + 分块
题目链接 Description "奋战三星期,造台计算机".小G响应号召,花了三小时造了台普通计算姬.普通计算姬比普通计算机要厉害一些.普通计算机能计算数列区间和,而普通计算姬能 ...
- [bzoj4766] 文艺计算姬 (矩阵树定理+二分图)
传送门 Description "奋战三星期,造台计算机".小W响应号召,花了三星期造了台文艺计算姬.文艺计算姬比普通计算机有更多的艺 术细胞.普通计算机能计算一个带标号完全图的生 ...
- 【bzoj4765】 普通计算姬
题意 给出一棵有根树,$n$个点每个都有一个点权.$m$组操作每次可以修改一个点权或者询问编号在区间$[l,r]$的点的子树权值和的和. Solution 我们对节点编号分块,每一块统计该块中的节点的 ...
- 【bzoj4765】普通计算姬
一道奇奇怪怪的数据结构题? 把树线性化,然后分块维护吧. 为了加速,求和用树状数组维护每个块的值. #include<bits/stdc++.h> #define N 100010 #de ...
- BZOJ 4765 普通计算姬 dfs序+分块+树状数组+好题!!!
真是道好题...感到灵魂的升华... 按dfs序建树状数组,拿前缀和去求解散块: 按点的标号分块,分成一个个区间,记录区间子树和 的 总和... 具体地,需要记录每个点u修改后,对每一个块i的贡献,记 ...
- bzoj 4766: 文艺计算姬 矩阵树定理
题目: 给定一个一边点数为\(n\),另一边点数为\(m\),共有\(n*m\)条边的带标号完全二分图\(K_{n,m}\) 计算其生成树个数 \(n,m,p \leq 10^{18} ,p为模数\) ...
随机推荐
- Android开发实现高德地图定位
1.获取Key 参考官方文档:http://lbs.amap.com/api/android-location-sdk/guide/create-project/get-key 对于签名文件的获取建议 ...
- Axure-计算输入字数
说明:Axure版本为7.0 1.添加多行文本框,设置名称为Input,添加文本框,设置名称为msg,样式如下: 2.为input添加“文本改变时”事件,设置全局变量,如下所示: 3.再添加“设置文本 ...
- Linux 使用常见问题
1. 如何查看软件安装到什么位置 [Ubuntu] 今天安装了Lxc-docker,想看一下文件都安装到哪里了,首先找到这个包的ersion zhouh1@uhome:~$ dpkg -s lxc-d ...
- SQL——将两列合并成一列
将两列合并连接成一列,需要注意的是列的格式必须是NVARCHAR或者VARCHAR类型 ), call_uuid, ) +','+agent_code ' PerDate 1 ,980408102 ...
- php同时查询两个表的数据
业务环境,表一 会员等级表, 表二会员表, 有一个字段是相同的 会员等级ID level 在会员的显示页面要直接显示会员的会员等级名称,不是等级ID. 1.同时查询两个表 2.表设置别名, selec ...
- Android(java)学习笔记173:服务(service)之绑定服务的细节
绑定服务的细节 1. 如果onbind方法返回值是null,onServiceConnect方法就不会被调用: 2. 绑定的服务,在系统设置界面,正在运行条目是看不到的: 3. 绑定的服务,不求同时生 ...
- Android(java)学习笔记159:多线程断点下载的原理(Android实现)
之前在Android(java)学习笔记215中,我们从JavaSE的角度去实现了多线程断点下载,下面从Android角度实现这个断点下载: 1. 新建一个Android工程: (1)其中我们先实现布 ...
- uva12433 Rent a Car
init 一开始搞成2*n+2了...囧 所以初始化很重要! 然后提交的时候忘了删调试的数据了..囧 技巧:设立虚拟节点 建图比较麻烦(非常). 要考虑到保养完了的车可以免费再用 设立S,T ,1 ...
- JDK 5 ~ 11 新特性倾情整理
为了大家对JDK有一个全面的了解,下面我为大家整理了JDK5~11的所有关键新特性! 先看一下JDK的版本迭代图: 注: OpenJDK和JDK区别 GPL协议通用性公开许可证(General ...
- 暑假集训 || 概率DP
Codeforces 148D 考虑状态转移..https://www.cnblogs.com/kuangbin/archive/2012/10/04/2711184.html题意:原来袋子里有w只白 ...