bzoj2568 比特集合
Description
INS M : 将元素 M 插入到集合S中;
DEL M : 将集合S中所有等于 M 的元素删除;
ADD M : 将集合S中的所有元素都增加数值M ;
QBIT k : 查询集合中有多少个元素满足其二进制的第 k位为 1 。
初始时,集合S为空集。请实现一个比特集合,并对于所有的QBIT操作输出相应的答案。
Input
接下来N行,每行为一个操作,格式见问题描述。
Output
Sample Input
INS 1
QBIT 0
ADD 1
QBIT 0
QBIT 1
DEL 2
INS 1
QBIT 1
Sample Output
0
1
0
HINT
数据规模和约定
时间限制2s。
对于30%的数据,1 ≤ N ≤ 10000。
对于100%的数据,1 ≤ N ≤ 500000;QBIT操作中的k满足, 0 ≤ k < 16。INS/DEL操作中,满足0 ≤ M ≤ 10^9;ADD操作中, 满足0 ≤ M ≤ 1000。
注意集合S可以包含多个重复元素。
正解:树状数组。
维护$16$个树状数组,其中第$i$个表示每个数$ \mod 2^{i+1}$的数是什么。
插入删除直接在树状数组里面搞就行了,查询某个数的个数直接$hash$就行了。
区间加就直接对于每个树状数组记录目前的$0$在哪个位置,不对树状数组进行修改。
查询就直接在$2^{k+1}$的树状数组上查询$[2^{k},2^{k+1}-1]$的数有多少个就行了。
#include <bits/stdc++.h>
#define il inline
#define RG register
#define ll long long
#define lb(x) (x & -x)
#define rhl (1253557) using namespace std; struct edge{ int nt,to,v; }g[]; int c[][],bin[],head[rhl+],n,m,num;
char ch[]; il int gi(){
RG int x=,q=; RG char ch=getchar();
while ((ch<'' || ch>'') && ch!='-') ch=getchar();
if (ch=='-') q=-,ch=getchar();
while (ch>='' && ch<='') x=x*+ch-,ch=getchar();
return q*x;
} il void insert(RG int from,RG int to,RG int v){
g[++num]=(edge){head[from],to,v},head[from]=num; return;
} il void add(RG int id,RG int x,RG int v){
for (;x<=bin[id+];x+=lb(x)) c[id][x]+=v; return;
} il int query(RG int id,RG int x){
RG int res=; for (;x;x-=lb(x)) res+=c[id][x]; return res;
} il void hshadd(RG int x,RG int v){
RG int wyh=(x%rhl+rhl)%rhl;
for (RG int i=head[wyh];i;i=g[i].nt)
if (g[i].to==x){ g[i].v+=v; return; }
insert(wyh,x,v); return;
} il int hshquery(RG int x){
RG int wyh=(x%rhl+rhl)%rhl;
for (RG int i=head[wyh];i;i=g[i].nt)
if (g[i].to==x) return g[i].v;
return ;
} int main(){
#ifndef ONLINE_JUDGE
freopen("bit.in","r",stdin);
freopen("bit.out","w",stdout);
#endif
n=gi(),bin[]=;
for (RG int i=;i<=;++i) bin[i]=bin[i-]<<;
for (RG int i=,x,k,l,r;i<=n;++i){
scanf("%s",ch);
if (ch[]=='I'){
x=gi();
for (RG int j=,y;j<=;++j){
y=(x-m)%bin[j+]; if (y<=) y+=bin[j+]; add(j,y,);
}
hshadd(x-m,);
}
if (ch[]=='D'){
x=gi(),k=hshquery(x-m); if (!k) continue;
for (RG int j=,y;j<=;++j){
y=(x-m)%bin[j+]; if (y<=) y+=bin[j+]; add(j,y,-k);
}
hshadd(x-m,-k);
}
if (ch[]=='A') m+=gi();
if (ch[]=='Q'){
k=gi(),l=(bin[k]-m)%bin[k+],r=(bin[k+]--m)%bin[k+];
if (l<=) l+=bin[k+]; if (r<=) r+=bin[k+];
if (l<=r) printf("%d\n",query(k,r)-query(k,l-));
else printf("%d\n",query(k,r)-query(k,l-)+query(k,bin[k+]));
}
}
return ;
}
bzoj2568 比特集合的更多相关文章
- BZOJ2568 比特集合(树状数组)
考虑维护f[k][x]表示“最低k位所表示的数不大于x”的数的个数.那么查询时答案就为f[k][2k-1]-f[k][2k-1-1]. 同时记录每个数在集合中出现多少次.这样的话插入.删除已经解决了, ...
- BZOJ2568 [国家集训队2012]比特集合
Description 比特集合是一种抽象数据类型(Abstract Data Type) ,其包含一个集合S,并支持如下几种操作: INS M : 将元素 M 插入到集合S中: DEL M : 将集 ...
- B2568 比特集合 树状数组
啊啊啊,跳题坑死人.抽了一道国集的题,自己瞎编了一个算法,好像过不了而半途而废.转去看题解,发现用二维树状数组维护一下,偏移量我倒是想对了,但是维护的东西和我的完全不一样.还是有很大差距啊... 题解 ...
- BZOJ 2568 比特集合
题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2568 题意:维护一个集合S,支持以下操作: (1)INS M : 将元素 M 插入 ...
- UML的概念模型
为 了理解UML,需要形成该语言的概念模型,这要求学习建模的3个要素:UML的基本构造块.支配这些构造块如何放在一起的规则和一些运用于整个UML的公 共机制.如果掌握了这些思想,就能够读懂UML模型, ...
- 关联规则算法Apriori的学习与实现
转自关联规则算法Apriori的学习与实现 首先我们来看,什么是规则?规则形如"如果-那么-(If-Then-)",前者为条件,后者为结果.关联规则挖掘用于寻找给定数据集中项之间的 ...
- 了解java虚拟机—垃圾回收算法(5)
引用计数器法(Reference Counting) 引用计数器的实现很简单,对于一个对象A,只要有任何一个对象引用了A,则A的引用计数器就加1,当引用失效时,引用计数器减1.只要对象A的引用计数器的 ...
- OpenGL和D3D11中的深度模版测试
在OpenGL和D3D11的管线中,像素shader之后的操作就是深度模版测试,深度模版测试是以sample为单位进行的,就是一个像素上可以有多个采样点,每个采样点都有深度信息.深度模版测试对 ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
随机推荐
- Jenkins自动化CI CD流水线之3--参数化构建
一. 背景 如果只是简单的构建,jenkins自己默认的插件可以做,但是如果我们想要在构建过程中有更多功能,比如说:选择性构建.传参.项目指定变量等等其他功能,基础的参数化构建可以实现一些简单功能,但 ...
- 利用Shell脚本实现远程MySQL自动查询
下面这个脚本是一个简单用来执行远程数据库查询的命令,相信大家都能看得懂,这对于有些需要每天自动检查数据库或是执行某些语句的兄弟,是很有帮助的,只要稍加修改就可以 #!/bin/shHOST=192.1 ...
- WireShark抓包分析(二)
简述:本文介绍了抓包数据含义,有TCP报文.Http报文.DNS报文.如有错误,欢迎指正. 1.TCP报文 TCP:(TCP是面向连接的通信协议,通过三次握手建立连接,通讯完成时要拆除连接,由于TCP ...
- hive默认配置 .hiverc
-- 切换数据库 use database_name; -- 优化本地查询 set hive.fetch.task.conversion=more; -- 设置hive的计算引擎为spark set ...
- java——编译和运行
Java源代码---->编译器---->Java字节码(即虚拟指令..class文件.特殊的二进制文件.二进制字节码文件)---->jvm---->解释器(jvm的一部分)-- ...
- 查看linux系统各种参数配置的命令
查看linux系统各种参数配置的命令 last |grep shutdown //查看上次关机时间 last |grep reboot ...
- Tomcat WEB搭建+Nginx负载均衡动静分离+DNS解析的实验
实验拓扑图: 实验环境: 在VMware workstation搭建虚拟环境,利用网络适配器的Nat和桥接模式模拟内网和外网环境. 实验过程中需要安装的工具包包括:vim unzip lrzsz ls ...
- JavaScript运算符优先级——"++,--,&&,||“
上篇文章比较了"?,="三者的优先级:"?">"=">"," 今天继续学习"++,--,& ...
- C语言实现通用链表初步(二)
接着上次的内容,我们继续! 还是无头单向非循环链表.假如要删除某个节点,如何实现? //删除成功返回0,失败返回-1 int slist_del(struct node_info *node, str ...
- BoostrapTable-本地模式(一次性加在所有数据)
直接上代码 数据: [ { "id": "1001", "name": "yyq", "isAdmin&quo ...