BZOJ2908: 又是nand
Description
Input
Output
Sample Input
2 7 3
1 2
2 3
Query 2 3
Replace 1 3
Query 1 1
Sample Output
7
HINT
100%的数据N、M≤100000,K≤32
我们发现nand这个东西啊,excited。。。
#include<cstdio>
#include<cctype>
#include<queue>
#include<cstring>
#include<algorithm>
#define rep(i,s,t) for(int i=s;i<=t;i++)
#define dwn(i,s,t) for(int i=s;i>=t;i--)
#define ren for(int i=first[x];i;i=next[i])
using namespace std;
const int BufferSize=1<<16;
char buffer[BufferSize],*head,*tail;
inline char Getchar() {
if(head==tail) {
int l=fread(buffer,1,BufferSize,stdin);
tail=(head=buffer)+l;
}
return *head++;
}
typedef unsigned int uint;
inline uint read() {
uint x=0,f=1;char c=Getchar();
for(;!isdigit(c);c=Getchar()) if(c=='-') f=-1;
for(;isdigit(c);c=Getchar()) x=x*10+c-'0';
return x*f;
}
const int maxn=100010;
int n,m,k,first[maxn],next[maxn<<1],to[maxn<<1],e;
void AddEdge(int u,int v) {
to[++e]=v;next[e]=first[u];first[u]=e;
to[++e]=u;next[e]=first[v];first[v]=e;
}
int fa[maxn],son[maxn],siz[maxn],dep[maxn];
void dfs(int x) {
dep[x]=dep[fa[x]]+1;siz[x]=1;
ren if(to[i]!=fa[x]) {
fa[to[i]]=x;dfs(to[i]);
siz[x]+=siz[to[i]];if(siz[to[i]]>siz[son[x]]) son[x]=to[i];
}
}
int top[maxn],pos[maxn],cnt;
void build(int x,int tp) {
top[x]=tp;pos[x]=++cnt;
if(son[x]) build(son[x],tp);
ren if(to[i]!=fa[x]&&to[i]!=son[x]) build(to[i],to[i]);
}
int lca(int x,int y) {
int f1=top[x],f2=top[y];
while(f1!=f2) {
if(dep[f1]<dep[f2]) swap(f1,f2),swap(x,y);
x=fa[f1];f1=top[x];
}
return dep[x]<dep[y]?x:y;
}
struct Node {
uint sum0,sum1;
}T[maxn<<2],T2[maxn<<2];
uint all,val[maxn];
uint nand(uint x,uint y) {return (x&y)^all;}
Node operator + (Node A,Node B) {
Node C;C.sum0=C.sum1=0;
rep(i,0,k-1) {
if(A.sum0>>i&1) {
if(B.sum1>>i&1) C.sum0|=1u<<i;
}
else {
if(B.sum0>>i&1) C.sum0|=1u<<i;
}
if(A.sum1>>i&1) {
if(B.sum1>>i&1) C.sum1|=1u<<i;
}
else {
if(B.sum0>>i&1) C.sum1|=1u<<i;
}
}
return C;
}
void maintain(int o) {
int lc=o<<1,rc=lc|1;
T[o]=T[lc]+T[rc];
T2[o]=T2[rc]+T2[lc];
}
void update(int o,int l,int r,int p,uint v) {
if(l==r) T[o]=T2[o]=(Node){nand(0,v),nand(all,v)};
else {
int mid=l+r>>1,lc=o<<1,rc=lc|1;
if(p<=mid) update(lc,l,mid,p,v);
else update(rc,mid+1,r,p,v);
maintain(o);
}
}
Node ans;
int flag;
void query(int o,int l,int r,int ql,int qr,int tp) {
if(ql<=l&&r<=qr) {
if(!flag) ans=(!tp?T[o]:T2[o]),flag=1;
else ans=ans+(!tp?T[o]:T2[o]);
}
else {
int mid=l+r>>1,lc=o<<1,rc=lc|1;
if(!tp) {
if(ql<=mid) query(lc,l,mid,ql,qr,tp);
if(qr>mid) query(rc,mid+1,r,ql,qr,tp);
}
else {
if(qr>mid) query(rc,mid+1,r,ql,qr,tp);
if(ql<=mid) query(lc,l,mid,ql,qr,tp);
}
}
}
int Ql[maxn],Qr[maxn],Top;
void query(int x,int y) {
int z=lca(x,y),f,ql,qr;
f=top[x];flag=0;
while(f!=top[z]) {
ql=pos[f];qr=pos[x];
query(1,1,n,ql,qr,1);
x=fa[f];f=top[x];
}
ql=pos[z];qr=pos[x];
query(1,1,n,ql,qr,1);
f=top[y];
while(f!=top[z]) {
ql=pos[f];qr=pos[y];
Ql[++Top]=ql;Qr[Top]=qr;
y=fa[f];f=top[y];
}
ql=pos[z]+1;qr=pos[y];
if(ql<=qr) Ql[++Top]=ql,Qr[Top]=qr;
while(Top) {
query(1,1,n,Ql[Top],Qr[Top],0);
Top--;
}
printf("%u\n",ans.sum0);
}
int main() {
n=read();m=read();k=read();
rep(i,0,k-1) all|=1ll<<i;
rep(i,1,n) val[i]=read();
rep(i,2,n) AddEdge(read(),read());
dfs(1);build(1,1);
rep(i,1,n) update(1,1,n,pos[i],val[i]);
rep(i,1,m) {
char c=Getchar();while(!isalpha(c)) c=Getchar();
int x=read(),y=read();
if(c=='Q') query(x,y);
else update(1,1,n,pos[x],y);
}
return 0;
}
BZOJ2908: 又是nand的更多相关文章
- 【BZOJ2908】又是nand 树链剖分+线段树
[BZOJ2908]又是nand escription 首先知道A nand B=not(A and B) (运算操作限制了数位位数为K)比如2 nand 3,K=3,则2 nand 3=not (2 ...
- 【BZOJ4811】[Ynoi2017]由乃的OJ 树链剖分+线段树
[BZOJ4811][Ynoi2017]由乃的OJ Description 由乃正在做她的OJ.现在她在处理OJ上的用户排名问题.OJ上注册了n个用户,编号为1-",一开始他们按照编号排名. ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- NAND Flash的基本操作——读、写、擦除
基本操作 这里将会简要介绍一下NAND Flash的基本操作在NAND Flash内部是如何进行的,基本操作包括:读.写和擦除. 读: 当我们读取一个存储单元中的数据时(如图2.4),是使 ...
- 怎么看时序图--nand flash的读操作详解(转载)
出处:http://blog.chinaunix.net/uid-28852942-id-3992727.html这篇文章不是介绍 nand flash的物理结构和关于nand flash的一些基本知 ...
- MTD下的Nand驱动
目录 MTD下的Nand驱动 引入 平台设备资源文件 关键数据结构 平台框架 s3c24xx_nand_probe nand_scan s3c2410_nand_add_partition add_m ...
- 怎么看时序图--nand flash的读操作详解
出处:http://blog.chinaunix.net/uid-28852942-id-3992727.html 这篇文章不是介绍 nand flash的物理结构和关于nand flash的一些基本 ...
- 转载:百为STM32开发板教程之十二——NAND FLASH
http://bbs.21ic.com/icview-586200-1-1.html 百为STM32开发板教程之十二——NAND FLASH 参考资料:百为stm32开发板光盘V3\百为stm32开发 ...
- 3D NAND闪存是个啥?让国内如此疯狂
Repost: https://news.mydrivers.com/1/477/477251.htm 上个月底武汉新芯科技主导的国家级存储器产业基地正式动工,在大基金的支持下该项目将投资240亿美元 ...
随机推荐
- codeblocks16.01 中配置Opencv3 姿势
VS太大安装时间长,考虑到效率问题,可以使用opencv+codeblocks opencv3没有codeblocks版本,需要自己编译,编译过程略. 已编译版本下载地址 http://pan.bai ...
- vmware 安装dos注意
vmware创建ms-dos虚拟机,安状DOS71.ISO. 新创建的机器,启动次序为Removable Devices/Hard Device/CD-ROM Device 新建的机器,第一次启动时, ...
- Asp.Net 数据库连接字符串
<configuration> <connectionStrings> <add name="DefaultConnection" providerN ...
- Unity3D 解决用Unity导出的Android工程在6.0及以上设备会弹出一串权限对话框的问题
解决用Unity导出的Android工程在6.0及以上设备会弹出一串权限对话框的问题 <meta-data android:name="unityplayer.SkipPermissi ...
- js识别当前用户设备的几个方法
公司要做一个APP下载页面,里面需要判断是安卓还是苹果访问本页面,最开始想偷懒直接在给IOSAPP返回IOSAPP商店地址,然后Android直接进行访问.但想着毕竟做两个页面不利于后期维护和修改,打 ...
- 【python】发送post请求
1. json格式的post请求 关键部分加粗显示了,主要是post数据的编码方式以及请求头的Content-type #coding=utf8 import json import gzip imp ...
- POJ 2823 Sliding Window 线段树区间求和问题
题目链接 线段树区间求和问题,维护一个最大值一个最小值即可,线段树要用C++交才能过. 注意这道题不是求三个数的最大值最小值,是求k个的. 本题数据量较大,不能用N建树,用n建树. 还有一种做法是单调 ...
- 虚拟机安装windows服务出现无法打开内核设备“\\.Global\vmx86”
解决方法: 在cmd下依次输入net start vmci,net start vmx86,net start VMnetuserif三个命令即可
- ESXI6.0启用 snmp
1.首先通过ILO登录远程控制桌面然后按F2输入密码后进入 2.开启shell 3.按住 Alt + F1 切换到shell 4.启用 snmp esxcli system snmp set -- ...
- CentOS7 安装中文帮助手册
1.首先确定系统安装中文字体否 locale 2.rpm安装中文帮助手册 挂在光盘 将man-pages-zh-CN-1.5.2-4.el7.noarch.rpm拷贝到本机 rpm -ivh man- ...