ACM-ICPC 2018 焦作赛区网络预赛 E Jiu Yuan Wants to Eat (树链剖分+线段树)
题目链接:https://nanti.jisuanke.com/t/31714
题意:给你一棵树,初始全为0,有四种操作:
1.u-v乘x 2.u-v加x 3. u-v取反 4.询问u-v的和
思路:
除去第三个操作就是很简单的树链剖分+线段树多重标记下放,所以我们只要考虑怎么维护第三个操作就好了,
由题目给的取反可知:!x = (2^64-1) - x; 但是这样维护还是很麻烦,因为这道题是对2^64取模的,我们可以
尝试把这个式子转换成只有加法和乘法的,这样就可以将其和前面两个操作一起维护降低难度。
我们可以想到: (-x)%(2^64) = (2^64-1)*x%(2^64),那么式子就可以转换成:
!x = (2^64-1)*x + (2^64-1) 这样这个式子就只有乘法和加法操作,以及一个常数,然后带入多重标记维护就好了
数组要开 unsigned long long ,题目给的模数也很特殊,2^64, 因为unsigned long long 溢出的时候相当于对2^64
取模,那么我们就不需要取模操作了,直接运算就完事了。
实现代码:
#include<bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define mid int m = (l + r) >> 1
#define ll unsigned long long
const ll inf = ;
const int M = 2e5+; vector<int>g[M];
int n,cnt1,cnt,a[M];
int son[M],fa[M],head[M],siz[M],top[M],dep[M],tid[M];
ll sum[M<<],add[M<<],mul[M<<]; void dfs1(int u,int faz,int deep){
dep[u] = deep;
fa[u] = faz;
siz[u] = ;
for(int i = ;i < g[u].size();i++){
int v = g[u][i];
//cout<<v<<" ";
if(v != fa[u]){
dfs1(v,u,deep+);
siz[u] += siz[v];
if(son[u] == -||siz[v] > siz[son[u]])
son[u] = v;
}
}
} void dfs2(int u,int t){
top[u] = t;
tid[u] = ++cnt;
if(son[u] == -) return;
dfs2(son[u],t);
for(int i = ;i<g[u].size();i++){
int v = g[u][i];
if(v != son[u]&&v != fa[u])
dfs2(v,v);
}
} void pushup(int rt){
sum[rt] = sum[rt<<] + sum[rt<<|];
} void pushdown(int m,int rt){
add[rt<<] = add[rt<<]*mul[rt] + add[rt];
add[rt<<|] = add[rt<<|]*mul[rt]+add[rt];
mul[rt<<] = mul[rt<<]*mul[rt];
mul[rt<<|] = mul[rt<<|]*mul[rt];
sum[rt<<] = sum[rt<<]*mul[rt] + add[rt]*(m-(m>>));
sum[rt<<|] = sum[rt<<|]*mul[rt]+add[rt]*(m>>);
add[rt] = ; mul[rt] = ;
} void build(int l,int r,int rt){
add[rt] = ; mul[rt] = ;
if(l == r){
sum[rt] = ;
return;
}
mid;
build(lson); build(rson);
pushup(rt);
} void update(int L,int R,ll c,int v,int l,int r,int rt){
if(L <= l&&R >= r){
if(v == ){
sum[rt] = sum[rt]*c;
add[rt] = add[rt]*c;
mul[rt] = mul[rt]*c;
}
else if(v == ){
sum[rt] = sum[rt] + (ll)c*(r-l+);
add[rt] = add[rt]+c;
}
else if(v == ){
sum[rt] = inf*sum[rt] + (r-l+)*inf;
add[rt] = add[rt]*inf+inf;
mul[rt] *= inf;
}
return;
}
pushdown(r-l+,rt);
int m = (l + r) >> ;
if(L <= m) update(L,R,c,v,lson);
if(R > m) update(L,R,c,v,rson);
pushup(rt);
} ll query(int L,int R,int l,int r,int rt){
if(L <= l&&R >= r){
return sum[rt];
}
mid;
pushdown(r-l+,rt);
ll ret = ;
if(L <= m) ret += query(L,R,lson);
if(R > m) ret += query(L,R,rson);
return ret;
} void cover(int x,int y,ll c,int v){
int fx = top[x],fy = top[y];
while(fx!=fy){
if(dep[fx] < dep[fy]) swap(fx,fy),swap(x,y);
update(tid[fx],tid[x],c,v,,n,);
x = fa[fx];fx = top[x];
}
if(dep[x] < dep[y]) swap(x,y);
update(tid[y],tid[x],c,v,,n,);
} ll ask(int x,int y){ //求两结点路径上的权值和
int fx = top[x],fy = top[y];
ll ans = ;
while(fx != fy){
if(dep[fx] < dep[fy]) swap(fx,fy),swap(x,y);
ans += query(tid[fx],tid[x],,n,);
x = fa[fx]; fx = top[x];
}
ans += (dep[x] > dep[y])?query(tid[y],tid[x],,n,):query(tid[x],tid[y],,n,);
return ans;
} void init(){
cnt = cnt1 = ;
memset(son,-,sizeof(son));
dep[] = ; fa[] = ; siz[] = ;
} int main()
{
int x,q,op,l,r;
ll c;
while(scanf("%d",&n)!=EOF){
init();
// cout<<inf<<endl;
for(int i = ;i <= n;i ++){
scanf("%d",&x);
g[x].push_back(i);
}
dfs1(,,);
dfs2(,);
build(,n,);
scanf("%d",&q);
while(q--){
scanf("%d",&op);
if(op == ||op == ){
scanf("%d%d%llu",&l,&r,&c);
cover(l,r,c,op);
}
else if(op == ){
scanf("%d%d",&l,&r);
cover(l,r,,op);
}
else {
scanf("%d%d",&l,&r);
printf("%llu\n",ask(l,r));
}
}
for(int i = ;i <= n;i ++)
g[i].clear();
}
return ;
}
ACM-ICPC 2018 焦作赛区网络预赛 E Jiu Yuan Wants to Eat (树链剖分+线段树)的更多相关文章
- ACM-ICPC 2018 焦作赛区网络预赛 E. Jiu Yuan Wants to Eat (树链剖分-线性变换线段树)
树链剖分若不会的话可自行学习一下. 前两种操作是线性变换,模\(2^{64}\)可将线段树全部用unsigned long long 保存,另其自然溢出. 而取反操作比较不能直接处理,因为其模\(2^ ...
- ACM-ICPC 2018 焦作赛区网络预赛- G:Give Candies(费马小定理,快速幂)
There are N children in kindergarten. Miss Li bought them NNN candies. To make the process more inte ...
- ACM-ICPC 2018 焦作赛区网络预赛- L:Poor God Water(BM模板/矩阵快速幂)
God Water likes to eat meat, fish and chocolate very much, but unfortunately, the doctor tells him t ...
- ACM-ICPC 2018 焦作赛区网络预赛
这场打得还是比较爽的,但是队友差一点就再过一题,还是难受啊. 每天都有新的难过 A. Magic Mirror Jessie has a magic mirror. Every morning she ...
- ACM-ICPC 2018 焦作赛区网络预赛J题 Participate in E-sports
Jessie and Justin want to participate in e-sports. E-sports contain many games, but they don't know ...
- ACM-ICPC 2018 焦作赛区网络预赛 K题 Transport Ship
There are NN different kinds of transport ships on the port. The i^{th}ith kind of ship can carry th ...
- ACM-ICPC 2018 焦作赛区网络预赛 L 题 Poor God Water
God Water likes to eat meat, fish and chocolate very much, but unfortunately, the doctor tells him t ...
- ACM-ICPC 2018 焦作赛区网络预赛 I题 Save the Room
Bob is a sorcerer. He lives in a cuboid room which has a length of AA, a width of BB and a height of ...
- ACM-ICPC 2018 焦作赛区网络预赛 H题 String and Times(SAM)
Now you have a string consists of uppercase letters, two integers AA and BB. We call a substring won ...
随机推荐
- HDMI传输原理:TMDS
参考资料:http://blog.sina.com.cn/s/blog_679686370100vgg1.html: http://www.eeworld.com.cn/mndz/2011/0818/ ...
- Luogu P3825 [NOI2017]游戏
这道题看上去NPC啊,超级不可做的样子. 我们先分析一下简单的情形:没有\(x\)地图 此时每个地图由于限制掉一种汽车,那么显然只会有两种选择. 再考虑到限制的情况,那么大致做法就很显然了--2-SA ...
- 基于uFUN开发板的心率计(二)动态阈值算法获取心率值
前言 上一篇文章:基于uFUN开发板的心率计(一)DMA方式获取传感器数据,介绍了如何获取PulseSensor心率传感器的电压值,并对硬件电路进行了计算分析.心率计,重要的是要获取到心率值,本篇文章 ...
- 安装zkpython出错
pip3 install zkpython==0.4.2 提示:zookeeper.c:20:23: 致命错误:zookeeper.h:没有那个文件或目录 解决: 1.是否安装python-devel ...
- 对于ps基本操作的归纳
1.开始新的制作 1)新建 快捷键:Ctrl+n 格式:宽高根据要求自选:颜色模式常用R(红)G(绿)B(蓝) 2)打开电脑上的图片 快捷键:Ctrl+o 2.选框工具 快捷键:M 作用:能 ...
- 一个高性能的对象属性复制类,支持不同类型对象间复制,支持Nullable<T>类型属性
由于在实际应用中,需要对大量的对象属性进行复制,原来的方法是通过反射实现,在量大了以后,反射的性能问题就凸显出来了,必须用Emit来实现. 搜了一圈代码,没发现适合的,要么只能在相同类型对象间复制,要 ...
- Nginx支持WebSocket反向代理-学习小结
WebSocket是目前比较成熟的技术了,WebSocket协议为创建客户端和服务器端需要实时双向通讯的webapp提供了一个选择.其为HTML5的一部分,WebSocket相较于原来开发这类app的 ...
- GlusterFS分布式存储学习笔记
分布式文件系统 分布式文件系统(Distributed File System)是指文件系统管理的物理存储资源并不直接与本地节点相连,而是分布于计算网络中的一个或者多个节点的计算机上.目前意义上的分布 ...
- PHP从入门到精通(五)
字符串三种声明方式 1."":双引号中可以解析变量"{$a}",双引号中可以使用任何转义字符:2.'':单引号中不可以解析变量,单引号中不可以使用转义字符(但是 ...
- LINUX内核分析第五周学习总结——扒开系统调用的“三层皮”(下)
LINUX内核分析第五周学习总结--扒开系统调用的"三层皮"(下) 标签(空格分隔): 20135321余佳源 余佳源 原创作品转载请注明出处 <Linux内核分析>M ...