bzoj 4811: [Ynoi2017]由乃的OJ
树链剖分,用zkw线段树维护每条链两个方向上对每一位的变换情况,由于位数较少,可以用两个unsigned long long表示
#include<cstdio>
typedef unsigned long long u64;
const int N=;
char buf[N*],*ptr=buf-;
int _(){
int x=,c=*++ptr;
while(c<)c=*++ptr;
while(c>)x=x*+c-,c=*++ptr;
return x;
}
u64 _u64(){
u64 x=;
int c=*++ptr;
while(c<)c=*++ptr;
while(c>)x=x*+c-,c=*++ptr;
return x;
}
int es[N*],enx[N*],e0[N],ep=,tp[N];
u64 v[N];
int fa[N],sz[N],top[N],dep[N],son[N],id[N],idp=,idr[N];
int n,m,k;
u64 vs[][];
void f1(int w,int pa){
dep[w]=dep[fa[w]=pa]+;
sz[w]=;
for(int i=e0[w];i;i=enx[i]){
int u=es[i];
if(u!=pa){
f1(u,w);
sz[w]+=sz[u];
if(sz[u]>sz[son[w]])son[w]=u;
}
}
}
void f2(int w,int tp){
top[w]=tp;
id[w]=++idp;
idr[idp]=w;
if(son[w])f2(son[w],tp);
for(int i=e0[w];i;i=enx[i]){
int u=es[i];
if(u!=fa[w]&&u!=son[w])f2(u,u);
}
}
int s1[],p1,s2[],p2,s3[],s4[],p3,p4;
void find(int l,int r,int tp){
p1=p2=;
for(l+=,r+=;r-l!=;l>>=,r>>=){
if(~l&)s1[p1++]=l^;
if(r&)s2[p2++]=r^;
}
if(!tp){
for(int i=;i<p2;++i)s4[p4++]=s2[i];
while(p1)s4[p4++]=s1[--p1];
}else{
for(int i=;i<p2;++i)s3[p3++]=s2[i];
while(p1)s3[p3++]=s1[--p1];
}
}
#define cal(a,b,c0,c1) (a)=((~(b)&(c0))|((b)&(c1)))
void init(int w,int tp,u64 v){
u64*a=vs[w];
if(tp==){
a[]=a[]=0ll&v;
a[]=a[]=-1ll&v;
}else if(tp==){
a[]=a[]=0ll|v;
a[]=a[]=-1ll|v;
}else if(tp==){
a[]=a[]=0ll^v;
a[]=a[]=-1ll^v;
}
}
void up(u64*a,u64*l,u64*r){
cal(a[],l[],r[],r[]);
cal(a[],l[],r[],r[]);
cal(a[],r[],l[],l[]);
cal(a[],r[],l[],l[]);
}
u64 _v0,_v1;
void get(int x,int y){
p3=p4=;
int a=top[x],b=top[y];
while(a!=b){
if(dep[a]>dep[b]){
find(id[a],id[x],);
x=fa[a],a=top[x];
}else{
find(id[b],id[y],);
y=fa[b],b=top[y];
}
}
if(dep[x]>dep[y]){
find(id[y],id[x],);
}else{
find(id[x],id[y],);
}
u64 v0=0ll,v1=-1ll;
for(int i=;i<p4;++i){
u64*a=vs[s4[i]];
cal(v0,v0,a[],a[]);
cal(v1,v1,a[],a[]);
}
while(p3){
u64*a=vs[s3[--p3]];
cal(v0,v0,a[],a[]);
cal(v1,v1,a[],a[]);
}
_v0=v0,_v1=v1;
}
int main(){
fread(buf,,sizeof(buf),stdin)[buf]=;
n=_();m=_();k=_();
for(int i=;i<=n;++i){
tp[i]=_();
v[i]=_u64();
}
for(int i=,a,b;i<n;++i){
a=_();b=_();
es[ep]=b;enx[ep]=e0[a];e0[a]=ep++;
es[ep]=a;enx[ep]=e0[b];e0[b]=ep++;
}
f1(,);f2(,);
for(int i=;i<=n;++i)init(id[i]+,tp[i],v[i]);
for(int i=;i;--i)up(vs[i],vs[i<<],vs[i<<|]);
for(int i=;i<m;++i){
int o=_(),x=_(),y=_();
u64 z=_u64();
if(o==){
get(x,y);
u64 r=,r0,r1;
for(int i=;i>=;--i)if((r|1llu<<i)<=z){
cal(r0,r,_v0,_v1);
cal(r1,(r|1llu<<i),_v0,_v1);
if(r0<r1)r|=1llu<<i;
}
cal(r0,r,_v0,_v1);
printf("%llu\n",r0);
}else{
init(id[x]+,tp[x]=y,v[x]=z);
for(int w=id[x]+>>;w!=;w>>=)up(vs[w],vs[w<<],vs[w<<^]);
}
}
return ;
}
bzoj 4811: [Ynoi2017]由乃的OJ的更多相关文章
- BZOJ 4811 [Ynoi2017]由乃的OJ ——Link-Cut Tree
直接维护按照顺序经过每一段,初始的1可以变成什么,初始为0可以变成什么. 然后答案就可以和起床困难综合征一样贪心处理了. 写起来并不好写. 发现交换左右子树之后答案会改变,GG 调了一天,最后还是T掉 ...
- bzoj 4811 由乃的OJ
bzoj 4811 由乃的OJ 考虑树链剖分. 树剖后用一颗线段树维护一段连续区间,类似于一个函数,各位上进入 \(0/1\) ,输出的数字分别是什么.注意到最多只有 \(64\) 位,可以用一个 \ ...
- 【BZOJ4811】[Ynoi2017]由乃的OJ 树链剖分+线段树
[BZOJ4811][Ynoi2017]由乃的OJ Description 由乃正在做她的OJ.现在她在处理OJ上的用户排名问题.OJ上注册了n个用户,编号为1-",一开始他们按照编号排名. ...
- BZOJ 3595: [Scoi2014]方伯伯的Oj SBT+可持久化Treap
3595: [Scoi2014]方伯伯的Oj Time Limit: 6 Sec Memory Limit: 256 MBSubmit: 102 Solved: 54[Submit][Status ...
- BZOJ4811 [Ynoi2017]由乃的OJ
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- 【bzoj4811】[Ynoi2017]由乃的OJ 树链剖分/LCT+贪心
Description 给你一个有n个点的树,每个点的包括一个位运算opt和一个权值x,位运算有&,l,^三种,分别用1,2,3表示. 每次询问包含三个数x,y,z,初始选定一个数v.然后v依 ...
- BZOJ 4810 [Ynoi2017]由乃的玉米田 (莫队 + bitset)
题目链接 BZOJ 4810 首先对询问离线, 莫队算法处理. 首先我们可以用bitset维护处当前区间中是否存在某个数. 对于询问1, 我们可以用 ((f >> q[i].x) &am ...
- bzoj4811 [Ynoi2017]由乃的OJ 树链剖分+位运算
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4811 因为位运算的结果有可合并性,所以可以树链剖分,线段树维护: 细节很多,特别要注意从左往 ...
- BZOJ 3595: [Scoi2014]方伯伯的Oj Splay + 动态裂点 + 卡常
Description 方伯伯正在做他的Oj.现在他在处理Oj上的用户排名问题. Oj上注册了n个用户,编号为1-”,一开始他们按照编号排名.方伯伯会按照心情对这些用户做以下四种操作,修改用户的排名和 ...
随机推荐
- Rodrigues(罗德里格斯)旋转公式推导
1. 2.推导过程:我们的目的是求得vrot,所以应该求得v||和vrot在垂直于k方向的投影向量. 其中, 俯视图看: 此外,另一种表示方法为: R可以看作旋转矩阵.
- SSAS aggregation 的作用及其使用
作用: 聚合是为了解决查询在运行时的效率低下,在数据立方体部署的时候进行聚合,实际上是对数据立方体的预处理,方便以后查询.如若在部署时未进行聚合,则在以后每次查询时实际上都会进行一次集合的操作,等待结 ...
- odoo软件名称及授权协议的变化
先看一张表格 起步时叫TinyERP,微小的ERP:发展中期叫做OpenERP,开放的ERP:历经10年积累的软件,客户群,开发支持用户群,开始构筑自己的商业模式.到8版本,改名为Odoo.同时,软件 ...
- 基于BP的B/S架构破解
思路历程: 1.获取用户名 2.获取密码字典 3.使用BP爆破 案例: 管理人员在平时的网络生活中没有良好的个人信息保护,让不法份子有机可乘.例如WordPress等的类似网站使用PHP开发,虽然功能 ...
- synchronized (string.intern())
在jdk7下慎用String.intern()作为synchronized的对象锁: https://www.cnblogs.com/yhlx/p/3498387.html String.intern ...
- redux笔记 进阶
1 拆分UI组件和容器组件 import React from 'react' const AppUI = (props) =>{ return ( <div className=&quo ...
- webpack执行命令参数
在webpack执行命令之后可以添加一些参数,这些参数都有自己的作用,下面是参数列表: $ webpack --config XXX.js //使用另一份配置文件(比如webpack.config2. ...
- SpringJDBC——jdbcTemplate模板
一.定义 Spring框架对jdbc进行了封装,提供的一个JDBCTemplated对象简化jdbc开发. 使用步骤 1 导包spring-beans-5.0.0-RELEASE.jar,spring ...
- Python中字典get方法的使用
Python中字典get方法的使用 说起来,这个功能是否需要学习还真是有待于讨论.其实,知道了字典这种数据结构以后,通过最基本的Python功能也能够实现一个类似的功能.不过,既然内置了这个功能那么我 ...
- 一个类似 Twitter 雪花算法 的 连续序号 ID 产生器 SeqIDGenerator
项目地址 : https://github.com/kelin-xycs/SeqIDGenerator 今天 QQ 群 里有网友问起产生唯一 ID 的方法 有哪些, 讨论了各种方法 . 有网 ...