hdu 3727 Jewel (可持久化线段树+bit)
链接: http://acm.hdu.edu.cn/showproblem.php?pid=3727
题意:
对一段序列进行四种操作:
Insert x :在序列尾部插入一个x;
Query_1 s t k : 求区间[s,t]中第k小的数
Query_2 x: 求x在序列中的排名
Query_3 k:求序列中第k小的数
思路;
第2,4个操作明显就是很裸的主席树求第k小。第3个操作我们可以单独用个树状数组维护,第一个操作因为会对序列造成影响,我们可以对所有操作进行离线处理,
分析完后可以发现这应该是一道比较简单的题。
主席树写搓了。。找了半天的错。。自闭
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define mid int m = (l + r) >> 1
#pragma comment(linker, "/STACK:102400000,102400000")
const int M = 2e5 + ;
int c[M],ls[M*],rs[M*],sum[M*],a[M],root[M],num;
ll ans1,ans2,ans3;
int n,len,cnt,idx;
void add(int x){
while(x <= len){
c[x] += ;
x += (x&-x);
}
} int getsum(int x){
int ans = ;
while(x){
ans += c[x];
x -= (x&-x);
}
return ans;
} void update(int &now,int l,int r,int p){
int old = now; now = ++idx;
ls[now] = ls[old]; rs[now] = rs[old];
sum[now] = sum[old] + ;
if(l == r) return ;
mid;
if(p <= m) update(ls[now],l,m,p);
else update(rs[now],m+,r,p);
} int query_1(int old,int now,int l,int r,int k){
if(l == r)
return l;
mid;
int ret = sum[ls[now]] - sum[ls[old]];
//cout<<sum[ls[now]]<<" "<<sum[ls[old]]<<endl;
if(ret >= k)
return query_1(ls[old],ls[now],l,m,k);
else
return query_1(rs[old],rs[now],m+,r,k-ret);
} int query_3(int &now,int l,int r,int k){
if(l == r) return l;
mid;
int ret = sum[ls[now]];
if(ret >= k) return query_3(ls[now],l,m,k);
else return query_3(rs[now],m+,r,k - ret);
} int find(int x){
return lower_bound(a+,a++len,x) - a;
} void init(){
cnt = ; idx = ; len = ,num = ;
ans1 = ; ans2 = ;ans3 = ;
memset(c,,sizeof(c));
memset(ls,,sizeof(ls));
memset(rs,,sizeof(rs));
memset(sum,,sizeof(sum));
memset(root,,sizeof(root));
} struct node{
int x,s,t,k;
}q[M];
char op[M][];
int main()
{
int cas = ;
while(scanf("%d",&n)!=EOF){
init();
for(int i = ;i <= n;i ++){
scanf("%s",op[i]);
if(op[i][] == 'I'){
scanf("%d",&q[i].x);
a[++cnt] = q[i].x;
}
else{
if(op[i][] == '')
scanf("%d%d%d",&q[i].s,&q[i].t,&q[i].k);
else if(op[i][] == '')
scanf("%d",&q[i].x),a[++cnt] = q[i].x;
else if(op[i][] == '')
scanf("%d",&q[i].k);
}
}
sort(a+,a++cnt);
len = unique(a+,a++cnt) - a-;
for(int i = ;i <= n;i ++){
if(op[i][] == 'I'){
int fx = find(q[i].x);
root[num] = root[num-];
update(root[num],,len,fx);
num++;
add(fx);
}
else{
if(op[i][] == '')
ans1 += a[query_1(root[q[i].s-],root[q[i].t],,len,q[i].k)];
else if(op[i][] == ''){
int fx = find(q[i].x);
ans2 += getsum(fx-) + ;
}
else if(op[i][] == '')
ans3 += a[query_3(root[num-],,len,q[i].k)];
//cout<<ans1<<" "<<ans2<<" "<<ans3<<" "<<endl;
}
}
printf("Case %d:\n",cas++);
printf("%lld\n%lld\n%lld\n",ans1,ans2,ans3);
}
return ;
}
/*
3 0
1 0
3 1
2 1
*/
hdu 3727 Jewel (可持久化线段树+bit)的更多相关文章
- HDU 3727 Jewel 可持久化线段树
Jewel Problem Description Jimmy wants to make a special necklace for his girlfriend. He bought man ...
- 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 ...
- HDU 4417.Super Mario-可持久化线段树(无修改区间小于等于H的数的个数)
Super Mario Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- HDU 5820 (可持久化线段树)
Problem Lights (HDU 5820) 题目大意 在一个大小为50000*50000的矩形中,有n个路灯.(n<=500000) 询问是否每一对路灯之间存在一条道路,使得长度为|x1 ...
- HDU 5919 Sequence II(可持久化线段树)
[题目链接]http://acm.hdu.edu.cn/showproblem.php?pid=5919 [题目大意] 给出一个数列,每次查询数列中,区间非重元素的下标的中位数.查询操作强制在线. [ ...
- 主席树[可持久化线段树](hdu 2665 Kth number、SP 10628 Count on a tree、ZOJ 2112 Dynamic Rankings、codeforces 813E Army Creation、codeforces960F:Pathwalks )
在今天三黑(恶意评分刷上去的那种)两紫的智推中,突然出现了P3834 [模板]可持久化线段树 1(主席树)就突然有了不详的预感2333 果然...然后我gg了!被大佬虐了! hdu 2665 Kth ...
- HDU 4348.To the moon SPOJ - TTM To the moon -可持久化线段树(带修改在线区间更新(增减)、区间求和、查询历史版本、回退到历史版本、延时标记不下放(空间优化))
To the moon Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total ...
- HDU 4866 Shooting(持久化线段树)
view code//第二道持久化线段树,照着别人的代码慢慢敲,还是有点不理解 #include <iostream> #include <cstdio> #include & ...
- HDU 4348 To the moon 可持久化线段树,有时间戳的区间更新,区间求和
To the moonTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/view.a ...
随机推荐
- 深度:Hadoop对Spark五大维度正面比拼报告!
每年,市场上都会出现种种不同的数据管理规模.类型与速度表现的分布式系统.在这些系统中,Spark和hadoop是获得最大关注的两个.然而该怎么判断哪一款适合你? 如果想批处理流量数据,并将其导入HDF ...
- C#批量插入数据到Sqlserver中的四种方式 - 转
先创建一个用来测试的数据库和表,为了让插入数据更快,表中主键采用的是GUID,表中没有创建任何索引.GUID必然是比自增长要快的,因为你生成一个GUID算法所花的时间肯定比你从数据表中重新查询上一条记 ...
- Python 学习 第七篇:函数1(定义、调用和变量的作用域)
函数是把一些语句集合在一起的程序结构,用于把复杂的流程细分成不同的组件,能够减少代码的冗余.代码的复用和修改代码的代价. 函数可以0个.1个或多个参数,向函数传递参数,可以控制函数的流程.函数还可以返 ...
- VitualBox安装linux记录
下载镜像 CentOS 7镜像下载 阿里云站点:http://mirrors.aliyun.com/centos/7/isos/x86_64/ VirtualBox安装linux https://ww ...
- 来不及说什么了,Python 运维开发剁手价仅剩最后 2 天
51reboot 运维开发又双叒叕的搞活动了—— Python 运维开发 18 天训练营课程, 剁手价1299 最后2天 上课方式:网络直播/面授(仅限北京) DAY1 - DAY4 Python3 ...
- BugkuCTF web3
前言 写了这么久的web题,算是把它基础部分都刷完了一遍,以下的几天将持续更新BugkuCTF WEB部分的题解,为了不影响阅读,所以每道题的题解都以单独一篇文章的形式发表,感谢大家一直以来的支持和理 ...
- Ceph分布式存储集群-硬件选择
在规划Ceph分布式存储集群环境的时候,对硬件的选择很重要,这关乎整个Ceph集群的性能,下面梳理到一些硬件的选择标准,可供参考: 1)CPU选择Ceph metadata server会动态的重新分 ...
- apache工作模式总结及网站访问缓慢处理记录
apache目前主要有两种模式:prefork模式和worker模式:1)prefork模式(默认模式)prefork是Unix平台上的默认(缺省)MPM,使用多个子进程,每个子进程只有一个线程.每个 ...
- <a>标签中href="javascript:;"** 为什么 style不用src**
&src/href <!--href 用于标示资源和文档关系,src 用于替换标签内容--> <img src="xxx.jpg"/> <sc ...
- Linux内核第八节 20135332武西垚
第一种分类: I/O-bound:频繁进行I/O,并且需要花费很多时间等待I/O完成 CPU-bound:计算密集,需要大量的CPU时间进行运算 第二种分类: 批处理进程:不必与用户交互,常在后台进行 ...