【XSY1098】第k小 可持久化trie
题目描述
给你一个长度为\(n\)数列\(a\),有\(m\)次操作:
\(1~x\):把所有数异或\(x\)
\(2~x\):把所有数与\(x\)
\(3~x\):把所有数或\(x\)
\(4~l~r~k\):求\(a_l\ldots a_r\)的第\(k\)小值。
\(n,m\leq 50000,0\leq x,a_i<2^{31}\)
题解
如果只有查询操作,可以用可持久化trie解决。
加上亦或操作,可以打标记解决。
与操作和或操作每次会将所有数的某些二进制变成一样,这些二进制位将来都是一样的。
所以直接暴力执行操作,然后打标记,表示这些二进制位已经相同了。如果与操作或或操作的\(x\)修改的二进制位都已经相同,就直接跳过。
时间复杂度:\(O(m\log x+n\log^2x)\)
代码
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cstdlib>
#include<ctime>
#include<utility>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pii;
int c[20000010][2];
int s[20000010];
int rt[50010];
int cnt;
int xo;
int insert(int x,int v,int d)
{
int y=++cnt;
s[y]=s[x]+1;
c[y][0]=c[x][0];
c[y][1]=c[x][1];
if(d==-1)
return y;
int b=(v>>d)&1;
c[y][b]=insert(c[y][b],v,d-1);
return y;
}
int query(int x,int y,int k,int d)
{
if(d==-1)
return 0;
int b=(xo>>d)&1;
if(s[c[y][b]]-s[c[x][b]]>=k)
return query(c[x][b],c[y][b],k,d-1);
return query(c[x][b^1],c[y][b^1],k-s[c[y][b]]+s[c[x][b]],d-1)|(1<<d);
}
int a[50010];
int n,m;
int all=0xffffffff,now=0;
void build()
{
int i;
cnt=0;
rt[0]=0;
for(i=1;i<=n;i++)
rt[i]=insert(rt[i-1],a[i],31);
}
int main()
{
freopen("xsy1098.in","r",stdin);
freopen("xsy1098.out","w",stdout);
int i,j;
scanf("%d%d",&n,&m);
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
build();
char op[5];
int x,y,k;
for(i=1;i<=m;i++)
{
scanf("%s",op);
if(op[0]=='X')
{
scanf("%d",&x);
xo^=x;
xo&=all;
now^=x&(~all);
}
else if(op[0]=='O')
{
scanf("%d",&x);
if(x&all)
{
all&=~x;
for(j=1;j<=n;j++)
a[j]&=all;
build();
}
now|=x&(~all);
xo&=all;
}
else if(op[1]=='n')
{
scanf("%d",&x);
if((~x)&all)
{
all&=x;
for(j=1;j<=n;j++)
a[j]&=all;
build();
}
now&=x&(~all);
xo&=all;
}
else
{
scanf("%d%d%d",&x,&y,&k);
int ans=query(rt[x-1],rt[y],k,31);
ans|=now;
printf("%d\n",ans);
}
}
return 0;
}
【XSY1098】第k小 可持久化trie的更多相关文章
- 区间第K小——可持久化线段树模板
概念 可持久化线段树又叫主席树,之所以叫主席树是因为这东西是fotile主席创建出来的. 可持久化数据结构思想,就是保留整个操作的历史,即,对一个线段树进行操作之后,保留访问操作前的线段树的能力. 最 ...
- POJ- 2104 hdu 2665 (区间第k小 可持久化线段树)
可持久化线段树 也叫函数式线段树也叫主席树,其主要思想是充分利用历史信息,共用空间 http://blog.sina.com.cn/s/blog_4a0c4e5d0101c8fr.html 这个博客总 ...
- HDU 2665.Kth number-可持久化线段树(无修改区间第K小)模板 (POJ 2104.K-th Number 、洛谷 P3834 【模板】可持久化线段树 1(主席树)只是输入格式不一样,其他几乎都一样的)
Kth number Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- SPOJ-COT-Count on a tree(树上路径第K小,可持久化线段树)
题意: 求树上A,B两点路径上第K小的数 分析: 同样是可持久化线段树,只是这一次我们用它来维护树上的信息. 我们之前已经知道,可持久化线段树实际上是维护的一个前缀和,而前缀和不一定要出现在一个线性表 ...
- 【XSY2720】区间第k小 整体二分 可持久化线段树
题目描述 给你你个序列,每次求区间第\(k\)小的数. 本题中,如果一个数在询问区间中出现了超过\(w\)次,那么就把这个数视为\(n\). 强制在线. \(n\leq 100000,a_i<n ...
- 【COGS 1534】 [NEERC 2004]K小数 &&【COGS 930】 [河南省队2012] 找第k小的数 可持久化01Trie
板子题,只是记得负数加fix最方便 #include <cstdio> ,N=; namespace FIFO { <<],*S=B,*T=B; #define getc() ...
- 树上第k小,可持久化线段树+倍增lca
给定一颗树,树的每个结点都有权值, 有q个询问,每个询问是 u v k ,表示u到v路径上第k小的权值是多少. 每个结点所表示的线段树,是父亲结点的线段树添加该结点的权值之后形成的新的线段树 c[ro ...
- 【set】【可持久化Trie】The 16th UESTC Programming Contest Preliminary K - Will the circle be broken
题意:You are given an array A of N non-negative integers and an integer M. Find the number of pair(i,j ...
- 可持久化Trie & 可持久化平衡树 专题练习
[xsy1629]可持久化序列 - 可持久化平衡树 http://www.cnblogs.com/Sdchr/p/6258827.html [bzoj4260]REBXOR - Trie 事实上只是一 ...
随机推荐
- Python全栈开发之路 【第一篇】:Python 介绍
本节内容 一.Python介绍 python的创始人为荷兰人——吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本 ...
- OO生存指南P1
写在OO作业之前 在正式写oo作业之前,先说一些“废话”吧,就当是对oo的吐槽. 事实上,早在大一的时候,听说数分很难,然而事实证明数分并没有有让我通宵的体验. 在大二上的时候有一门课叫祭祖,号称是第 ...
- App Inspector-iOS真机功能详解
前言: App Inspector:浏览器端的移动设备 UI 查看器,使用树状态结构查看 UI 布局,自动生成 XPaths.官网:https://macacajs.github.io/app-ins ...
- C++类的描述
类的描述分为两个部分,public和private public可以用来定义函数,对类的对象进行操作,对于用户是可见的,是用户对对象操作的唯一手段. private部分用于定义函数和数据成员,这些函数 ...
- 网络编程-C/S架构
什么是C/S架构 C指的是client(客户端软件),S指的是Server(服务端软件),本章的重点就是教大家写一个C/S架构的软件,实现服务端软件与客户端软件基于网络通信. 计算机基础知识 作为应用 ...
- c#中用sql存储过程
string connstr = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionStri ...
- Shell脚本命令图片
查看相关文档:shell脚本1 shell脚本2
- PAT L2-009 抢红包
https://pintia.cn/problem-sets/994805046380707840/problems/994805066890854400 没有人没抢过红包吧…… 这里给出N个人之间互 ...
- 配置nginx反向代理服务器,解决浏览器跨域调用接口的限制问题
配置nginx反向代理服务器,解决浏览器跨域调用接口的限制问题 - 大venn的博客 - CSDN博客https://blog.csdn.net/u011135260/article/details/ ...
- md5加密通过URL传给后台
首先要把你要用的md5库引入 这个技术其实挺简单的,咋们直接贴上代码(这个是项目上的) sign = hex_md5("type="+type&"userId=& ...