CF757G Can Bash Save the Day?
CF757G Can Bash Save the Day?
#include<bits/stdc++.h>
#define RG register
#define IL inline
#define _ 200100
#define ycb (1<<30)
#define ll long long
using namespace std;
IL int gi(){
RG int data = 0 , m = 1; RG char ch = 0;
while(ch != '-' && (ch<'0' || ch > '9')) ch = getchar();
if(ch == '-'){m = 0; ch = getchar();}
while(ch>='0' && ch<='9'){data = (data<<1) + (data<<3) + ch - '0' ; ch = getchar();}
return (m) ? data : -data ;
}
int fa[_],son[_],sz[_],dep[_],dfn[_],top[_];
struct YCB{int ls,rs; ll tag,sum;} t[120*_] ; int n,Q,a[_],rt[_],tot;
struct Road{int to,next,w;}edg[2*_] ; int head[_],cnt; ll dis[_],bit[_],ans,predist[_];
IL void add(int u,int v,int w){
edg[++cnt] = (Road){v , head[u] , w} ; head[u] = cnt ;
}
void dfs1(int u,int fth,ll dist){
fa[u] = fth; dis[u] = dist;
son[u] = 0; sz[u] = 1;
for(int i = head[u]; i; i = edg[i].next){
int v = edg[i].to;
if(v == fth)continue;
dfs1(v,u,dist + edg[i].w);
if(!son[u] || sz[son[u]] < sz[v])son[u] = v;
sz[u] = sz[u] + sz[v];
}
}
void dfs2(RG int u,RG int upp){
top[u] = upp; dfn[u] = ++cnt;
predist[cnt] = predist[cnt-1] + dis[u] - dis[fa[u]] ;
if(son[u]) dfs2(son[u] ,upp) ; else return ;
for(RG int i = head[u] ; i ; i = edg[i].next){
RG int v = edg[i].to;
if(v == fa[u] || v == son[u]) continue;
if(v != son[u]) dfs2(v , v) ;
}return ;
}
IL void Pre(){
n = gi(); Q = gi();
for(RG int i = 1; i <= n; i ++) a[i] = gi() ;
for(RG int i = 1,u,v,w; i <= n-1; i ++)
u = gi() , v = gi() , w = gi() , add(u,v,w) , add(v,u,w) ;
dfs1(1,0,0); cnt = 0; dfs2(1,1);
}
IL void Ins(int x,ll d){while(x<=n)bit[x] += d , x += (x&-x); }
IL ll get(int x){RG ll ret = 0; while(x)ret += bit[x] , x -= (x&-x); return ret ; }
void Build(int &o,int l,int r){
o = ++ tot;
t[o].tag = t[o].sum =0; if(l == r)return ;
RG int mid = (l + r) >> 1;
Build(t[o].ls , l , mid) ; Build(t[o].rs , mid + 1 , r) ;
}
void Update(int &o,int l,int r,int ql,int qr){
t[++tot] = t[o]; o = tot;
if(ql == l && r == qr){t[o].tag++; return ; }
t[o].sum += predist[qr] - predist[ql-1] ;
RG int mid = (l + r) >> 1;
if(qr <= mid) Update(t[o].ls , l , mid , ql , qr) ;
else if(ql > mid) Update(t[o].rs , mid + 1, r , ql , qr) ;
else Update(t[o].ls,l,mid,ql,mid) , Update(t[o].rs,mid+1,r,mid+1,qr) ;
}
ll Query(int o,int l,int r,int ql,int qr){
RG ll dt = 1ll * t[o].tag * (predist[qr]-predist[ql-1]) ;
if(ql == l && r == qr) return t[o].sum + dt;
RG int mid = (l + r) >> 1;
if(qr <= mid) return dt + Query(t[o].ls , l , mid , ql , qr) ;
if(ql > mid) return dt + Query(t[o].rs , mid + 1 , r , ql , qr) ;
return dt + Query(t[o].ls , l , mid , ql , mid) + Query(t[o].rs , mid + 1, r , mid + 1, qr);
}
IL void Modify_Pre(int P,int p){
while(top[p] ^ 1)
Update(rt[P] , 1 , n , dfn[top[p]] , dfn[p]) ,
p = fa[top[p]] ;
if(p ^ 1) Update(rt[P] , 1 , n , dfn[son[1]] , dfn[p]) ;
}
IL ll Calc_Pre(int root,int p){
RG ll ret = 0;
while(top[p] ^ 1)
ret = ret + Query(root , 1 , n , dfn[top[p]] , dfn[p]) ,
p = fa[top[p]] ;
if(p ^ 1) ret += Query(root , 1 , n , dfn[son[1]] , dfn[p]) ;
return ret ;
}
int main(){
Pre();
Build(rt[0] , 1 , n) ;
for(RG int i = 1; i <= n; i ++)
rt[i] = rt[i-1] , Modify_Pre(i , a[i]) ;
for(RG int i = 1; i <= n; i ++) Ins(i , dis[a[i]]) ;
RG int opt,l,r,x;
ans = 0;
while(Q--){
opt = gi();
if(opt == 2) x = gi() ;
else l = gi() , r = gi() , x = gi() ;
l = (ans % ycb) ^ l ;
r = (ans % ycb) ^ r ;
x = (ans % ycb) ^ x ;
if(l > r) swap(l , r) ;
if(opt == 1){
ans = 0;
ans += 1ll * (r-l+1) * dis[x] ;
ans += get(r) - get(l-1) ;
ans -= 1ll * 2 * (Calc_Pre(rt[r] , x) - Calc_Pre(rt[l-1] , x));
printf("%lld\n" , ans) ;
}
else if(opt == 2){
rt[x] = rt[x-1] ;
Modify_Pre(x , a[x+1]) ;
Ins(x , -dis[a[x]]); Ins(x+1 , -dis[a[x+1]]);
swap(a[x] , a[x+1]) ;
Ins(x , dis[a[x]]) ; Ins(x+1 , dis[a[x+1]]) ;
}
}return 0;
}
CF757G Can Bash Save the Day?的更多相关文章
- 【CF757G】Can Bash Save the Day? 可持久化点分树
[CF757G]Can Bash Save the Day? 题意:给你一棵n个点的树和一个排列${p_i}$,边有边权.有q个操作: 1 l r x:询问$\sum\limits_{i=l}^r d ...
- [Codeforces757G]Can Bash Save the Day?——动态点分治(可持久化点分树)
题目链接: Codeforces757G 题目大意:给出一棵n个点的树及一个1~n的排列pi,边有边权,有q次操作: 1 l r x 求 $\sum\limits_{i=l}^{r}dis(p_{i} ...
- alfresco install in linux, and integrated with tesseract ocr
本文描述在Linux系统上安装Alfresco的步骤: 1. 下载安装文件:alfresco-community-5.0.d-installer-linux-x64.bin 2. 增加执行权限并执行: ...
- Docker详解(上)
Docker 学习 Docker概述 Docker安装 Docker命令 镜像命令 容器命令 操作命令 ... Docker镜像 容器数据卷 DockerFile Docker网络原理 IDEA整合D ...
- cmder git bash 使用
cmder 是一款 windows 下的命令集合软件,它可以集合各种系统下的命令,并且操作非常快速方便. 安装有两个版本,一个是简化版(4.27M),一个是完全版(75.7M),它们的唯一区别:完全版 ...
- read name 和 read 在 Bash 中的区别
read 带一个参数和不带参数的区别是什么,我本以为仅仅是被赋值的变量的名字不同而已: $ read name 1 $ echo "$name" 1 $ read 1 $ echo ...
- How can i use iptables save on centos 7?
I installed CentOS 7 with minimal configuration (os + dev tools). I am trying to open 80 port for ht ...
- Git bash 配置ssh key
问题描述 昨天为了配置Qt create中的Git,把我一直在使用的Github删除了,今本以为,这样git的一些配置还在,可是,今天上传一些提交的时候,提示我,git没有密钥.梳理一下,这个简单的配 ...
- 深入体验bash on windows,在windows上搭建原生的linux开发环境,酷!
今年微软Build 2016大会最让开发人员兴奋的消息之一,就是在Windows上可以原生运行Linux bash,对开发人员来说,这是一个喜闻乐见的消息. 1 安装 你必须安装开发者预览版本,才能使 ...
随机推荐
- 03-JVM内存模型:堆与方法区
一.堆(Heap) 1.1.什么是堆 堆是用于存放对象的内存区域.因此,它是垃圾收集器(GC)管理的主要目标.其具有以下特点: 堆在逻辑上划分为“新生代”和“老年代”.由于JAVA中的对象大部分是朝生 ...
- Appium-原理、设置
Appium是支持跨平台的移动端自动化测试框架. 下面介绍下Appium的具体工作流程: 首先,Appium server 默认监听4723端口,监听客户端的命令. 客户端指的是 我们编写的自动化测试 ...
- 【SpringCloud 】第八篇: 消息总线(Spring Cloud Bus)
前言: 必需学会SpringBoot基础知识 简介: spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.微代理.事件总线.全局锁.决策竞选. ...
- 第一阶段·Linux运维基础-第2章·Linux系统目录结构介绍
01 变量与PS1 02 添加用户 03 关闭SELinux 04 关闭iptables 05 显示中文乱码排查过程 06 总结 07 目录结构课程内容 08 Linux目录结构特点 09 Linux ...
- lesson 23 one man's meat is another man's poison
lesson 23 one man's meat is another man's poison delicacy n. 美味:佳肴: delicious adj. 美味的:可口的 关于虚拟语气: I ...
- lintcode 二叉树中序遍历
/** * Definition of TreeNode: * class TreeNode { * public: * int val; * TreeNode *left, *right; * Tr ...
- 389. Valid Sudoku【LintCode java】
Description Determine whether a Sudoku is valid. The Sudoku board could be partially filled, where e ...
- pymsql报错:UnicodeEncodeError: 'latin-1' codec can't encode characters End,OK!!
UnicodeEncodeError: 'latin-1' codec can't encode characters的做法基本一致,后来发现是因为使用的是mysqldb,照着网上的方法修改配置应该可 ...
- 【MFC】VS2017新建完MFC后,没有界面,只有代码
问题描述:双击.rc文件后提示在另一个编辑器中打开 解决方法整合: 1----- 打开工程之前先把.rc文件改个名称,然后打开工程双击解决方案管理器的.rc文件, 会显示"载入失败" ...
- 衡量生活成本:消费者价格指数(CPI, Consumer Price Index)
经济学家应该如何把经济中的许多价格加总成一个单一指数,从而能够衡量价格的总体水平呢?他们可以简单地计算所有产品与服务价格的平均值,但是这种方法的不足之处是把所有的产品与服务等同处理.由于人们购买的鸡比 ...