bzoj 3920: Yuuna的礼物
Description
Input
Output
很显然可以用莫队算法,关键在于维护状态转移。权值分块可以做到O(1)插入/删除,O(√(n))查询第k大,可以用于维护每种出现次数有几个权值以及相同出现次数的不同权值。由均摊分析可知,每种出现次数的权值数之和为n,于是可以预处理离散化并给每个出现次数的权值分块分配对应的空间。可以做到O(n)预处理,O(m√(n))查询,O(n)空间,但常数较大。
#include<cstdio>
#include<algorithm>
#include<cmath>
int _(){
int x=,c=getchar();
while(c<)c=getchar();
while(c>)x=x*+c-,c=getchar();
return x;
}
int n,m,v[],B,id[],ts[],ans[],t1[],t2[],mt[],mc[];
int*l0[],*r0[],*l1[],*l2[],*l3[],_mem[],*mp=_mem;
struct Q{
int l,r,k1,k2,ID;
void init(int i){
l=_();r=_();k1=_();k2=_();ID=i;
}
bool operator<(const Q&w)const{
return id[l]!=id[w.l]?id[l]<id[w.l]:r!=w.r?(r<w.r)!=(id[l]&):ID<w.ID;
}
}q[];
void insv(int x,int y){
if(!t1[x]++)++t2[x/B];
y=l3[y][x];
++l1[x][y];
++l2[x][y/B];
}
void delv(int x,int y){
if(!--t1[x])--t2[x/B];
y=l3[y][x];
--l1[x][y];
--l2[x][y/B];
}
void ins(int x){
if(ts[x]>)delv(ts[x],x);
++ts[x];
if(ts[x]>)insv(ts[x],x);
}
void del(int x){
if(ts[x]>)delv(ts[x],x);
--ts[x];
if(ts[x]>)insv(ts[x],x);
}
int rnk(int x,int k){
for(int i=,s=;;++i){
if(s+l2[x][i]>=k){
for(int j=i*B;;++j)if((s+=l1[x][j])==k)return l0[x][j];
}
s+=l2[x][i];
}
}
int main(){
n=_();
B=sqrt(n+)+;
for(int i=;i<=n;++i)++mc[++mt[v[i]=_()]],id[i]=(i-)/B;
for(int i=;i<=n;++i){
l0[i]=r0[i]=mp;mp+=mc[i];
l1[i]=mp;mp+=mc[i];
l2[i]=mp;mp+=mc[i];
l3[i]=mp-;mp+=mt[i];
}
for(int i=;i<=n;++i)for(int j=;j<=mt[i];++j)l3[i][j]=r0[j]-l0[j],*r0[j]++=i;
m=_();
for(int i=;i<m;++i)q[i].init(i);
std::sort(q,q+m);
int L=,R=;
for(int i=;i<m;++i){
int l=q[i].l,r=q[i].r;
while(L>l)ins(v[--L]);
while(L<l)del(v[L++]);
while(R<r)ins(v[++R]);
while(R>r)del(v[R--]);
for(int j=,s=;;++j){
if(s+t2[j]>=q[i].k1){
int k=B*j;
while(s<q[i].k1)if(t1[k++])++s;--k;
ans[q[i].ID]=rnk(k,q[i].k2);
break;
}
s+=t2[j];
}
}
for(int i=;i<m;++i)printf("%d\n",ans[i]);
return ;
}
bzoj 3920: Yuuna的礼物的更多相关文章
- BZOJ.3920.Yuuna的礼物(莫队 分块套分块 分段离散化)
题目链接 详细题解:https://www.cnblogs.com/autsky-jadek/p/4376091.html 代码参考自:https://www.cnblogs.com/Sakits/p ...
- bzoj3920: Yuuna的礼物(莫队+分块套分块)
思路挺简单的,但是总感觉好难写...码力还是差劲,最后写出来也挺丑的 这题显然是个莫队题,考虑怎么转移和询问... 根据莫队修改多查询少的特点,一般用修改快查询慢的分块来维护.查第$k_1$小的出现次 ...
- 【莫队算法】【权值分块】bzoj3920 Yuuna的礼物
[算法一] 暴力. 可以通过第0.1号测试点. 预计得分:20分. [算法二] 经典问题:区间众数,数据范围也不是很大,因此我们可以: ①分块,离散化,预处理出: <1>前i块中x出现的次 ...
- [BZOJ3920]Yuuna的礼物
题目大意: 给你一个长度为$n(n\le40000)$的数列$\{a_i\}(1\le a_i\le n)$,给出$m(m\le40000)$次询问,每次给出$l,r,k_1,k_2$询问区间$[l, ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- bzoj 3055礼物运送 floyed + 状压DP
bzoj 3055: 礼物运送 floyed first 设f[i][S]表示取到了S集合中的所有点(不一定是经过的所有点),最后停在了i的最优值. 初始就f[i][{i}] = dis[1][i] ...
- bzoj 4827 礼物
bzoj 4827 礼物 可以看做将其中一个数列(假定为 \(a\) )都加上 \(c\) , \(c\) 可以为负数.易知这里 \(-m\leq c\leq m\). 记要求的答案为 \(ans\) ...
- BZOJ 3438 小M的礼物
BZOJ 3438 小M的礼物 Description 小M在MC里开辟了两块巨大的耕地A和B(你可以认为容量是无穷),现在,小P有n中作物的种子,每种作物的种子 有1个(就是可以种一棵作物)(用1. ...
- bzoj 4827: [Hnoi2017]礼物 [fft]
4827: [Hnoi2017]礼物 题意:略 以前做的了 化一化式子就是一个卷积和一些常数项 我记着确定调整值还要求一下导... #include <iostream> #include ...
随机推荐
- SqlServer 杂记 不断补充中
1.OPTION (MAXRECURSION 25) :最大允许递归的次数.默认最大CTE递归只有100次,而你要求插入10年的数据,需要递归3000多次,所以要使用option (MAXRECURS ...
- Sprint第二个冲刺(第四天)
一.Sprint 计划会议: 第四次会议总结情况如下展示:昨天完成了美化按钮.增添图片的功能,今天在我们的努力下又完成了查看用户资料和底栏显示功能,由此可见我们团队的小伙伴都很厉害,也很勤奋.从燃尽图 ...
- session处理超时的三种方式
1. 在web容器中设置(此处以tomcat为例) 在tomcat-5.0.28\conf\web.xml中设置,以下是tomcat 5.0中的默认配置: <!-- ========= ...
- C++ Primer : 第十一章 : 关联容器示例: 一个单词转换的map
单词转换就是:将一些缩写的单词转换为实际的文本.第一个文件保存的是转换的规则,而第二个文件保存的是要转换的文本. 假设单词转换的规则的文件如下: brb be right back k okay? y ...
- UpdatePanel与$.function()同时使用问题
在.NET中使用了UpdatePanel,里面的输入框使用了jQuery的日历选择器,接下来介绍下两者同时使用的一些细节及问题的解决方法,感兴趣的各位可以参考下哈 今天,在.NET中使用了Update ...
- HDU 1010 Tempter of the Bone --- DFS
HDU 1010 题目大意:给定你起点S,和终点D,X为墙不可走,问你是否能在 T 时刻恰好到达终点D. 参考: 奇偶剪枝 奇偶剪枝简单解释: 在一个只能往X.Y方向走的方格上,从起点到终点的最短步数 ...
- NodeJS记录
https://nqdeng.github.io/7-days-nodejs/#3.3.4
- MFC开发上位机到底用Dialog结构还是文档结构?
最近要跟着导师一起开发一款大型上位机.MFC新人在考虑用对话框结构还是文档结构. 虽然说书上说大型结构的软件都需要文档结构,但是目前来看,对话框可以实现功能,并且对话框的程序更小一些,节省资源加载速度 ...
- ADC 分辨率和精度的区别
分辨率和精度这两个,经常拿在一起说,才接触的时候经常混为一谈.对于ADC来说,这两样也是非常重要的参数,往往也决定了芯片价格,显然,我们都清楚同一个系列,16位AD一般比12位AD价格贵,但是同样是1 ...
- C++静态存储,动态存储
什么是静态存储,动态存储静态存储变量通常是在变量定义时就分定存储单元并一直保持不变, 直至整个程序结束. 动态存储变量是在程序执行过程中,使用它时才分配存储单元, 使用完毕立即释放.典型的例子是函数的 ...