刚学了整体二分,用这种解法来解决这道题。

首先对于每个询问时可以二分解决的,这也是可以使用整体二分的前提。将原来的序列看成是插入操作,和询问操作和在一起根据值域进行二分。用树状数组来检验二分值。

 1 #include<bits/stdc++.h>
2 using namespace std;
3 const int N=100010,INF=1e9;
4 struct node{
5 int op,x,y,z;
6 }q[N<<1],lq[N<<1],rq[N<<1];
7 int n,m,t,c[N],ans[N];
8
9 int lowbit(int x){
10 return x&(-x);
11 }
12
13 int ask(int x){
14 int sum=0;
15 while(x){
16 sum+=c[x];
17 x-=lowbit(x);
18 }
19 return sum;
20 }
21
22 void change(int x,int y){
23 while(x<=n){
24 c[x]+=y;
25 x+=lowbit(x);
26 }
27 }
28
29 void solve(int L,int R,int l,int r){
30 if(l>r) return ;//操作序列为空
31 if(L==R){
32 for(int i=l;i<=r;i++){
33 if(q[i].op>0) ans[q[i].op]=L;
34 }
35 return ;
36 }
37 int mid=(L+R)>>1;
38 int lt=0,rt=0;
39 for(int i=l;i<=r;i++){
40 if(q[i].op==0){
41 if(q[i].y<=mid) change(q[i].x,1),lq[++lt]=q[i];
42 else rq[++rt]=q[i];
43 }
44 else{
45 int cnt=ask(q[i].y)-ask(q[i].x-1);
46 if(cnt>=q[i].z) lq[++lt]=q[i];
47 else q[i].z-=cnt,rq[++rt]=q[i];
48 }
49 }
50 for(int i=r;i>=l;i--){
51 if(q[i].op==0 && q[i].y<=mid) change(q[i].x,-1);
52 }
53 for(int i=1;i<=lt;i++) q[l+i-1]=lq[i];
54 for(int i=1;i<=rt;i++) q[l+lt+i-1]=rq[i];
55 solve(L,mid,l,l+lt-1);
56 solve(mid+1,R,l+lt,r);
57 }
58
59 int main(){
60 scanf("%d%d",&n,&m);
61 for(int i=1;i<=n;i++){
62 int val;scanf("%d",&val);
63 q[++t].op=0,q[t].x=i,q[t].y=val;
64 }
65 for(int i=1;i<=m;i++){
66 int l,r,k;
67 scanf("%d%d%d",&l,&r,&k);
68 q[++t].op=i,q[t].x=l,q[t].y=r,q[t].z=k;
69 }
70 solve(-INF,INF,1,t);
71 for(int i=1;i<=m;i++) printf("%d\n",ans[i]);
72 return 0;
73 }

POJ2104 K-th number (整体二分)的更多相关文章

  1. POJ2104 K-th Number [整体二分]

    题目传送门 K-th Number Time Limit: 20000MS   Memory Limit: 65536K Total Submissions: 69053   Accepted: 24 ...

  2. POJ2104 K-th Number(整体二分)

    题解 又一次做这个题上一次用的是线段树上二分.这次用的是整体二分.结果: (第一个是整体二分) 整体二分就是对于所有查询都二分一个值.然后根据能不能成立把询问修改分成两部分,然后第二部分继承第一部分的 ...

  3. BZOJ 3110: [Zjoi2013]K大数查询 [整体二分]

    有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数是多少. N ...

  4. BZOJ3110:[ZJOI2013]K大数查询(整体二分)

    Description 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c.如果是2 a b c形式,表示询问从第a个位置到第b个位 ...

  5. BZOJ 3110 K大数查询 | 整体二分

    BZOJ 3110 K大数查询 题面 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c 如果是2 a b c形式,表示询问从第a个 ...

  6. BZOJ.3110.[ZJOI2013]K大数查询(整体二分 树状数组/线段树)

    题目链接 BZOJ 洛谷 整体二分求的是第K小(利用树状数组).求第K大可以转为求第\(n-K+1\)小,但是这样好像得求一个\(n\). 注意到所有数的绝对值\(\leq N\),将所有数的大小关系 ...

  7. 【BZOJ-3110】K大数查询 整体二分 + 线段树

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6265  Solved: 2060[Submit][Sta ...

  8. 静态区间第K小(整体二分、主席树)

    题目链接 题解 主席树入门题 但是这里给出整体二分解法 整体二分顾名思义是把所有操作放在一起二分 想想,如果求\([1-n]\)的第\(k\)小怎么二分求得? 我们可以二分答案\(k\), \(O(n ...

  9. ZOJ 1112 Dynamic Rankings【动态区间第K大,整体二分】

    题目链接: http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1112 题意: 求动态区间第K大. 分析: 把修改操作看成删除与增加 ...

  10. [ZJOI2013]K大数查询——整体二分

    题目描述 有N个位置,M个操作.操作有两种,每次操作如果是: 1 a b c:表示在第a个位置到第b个位置,每个位置加上一个数c 2 a b c:表示询问从第a个位置到第b个位置,第C大的数是多少. ...

随机推荐

  1. 二位数组——扩展:冒泡排序、Arrays类

    1.冒泡排序 速记口诀(升序)   n个数字来排队:两两相比小靠前:外层循环n-1:内层循环n-i-1. 示例:定义一个数组,用冒泡排序将数组进行升序排序 关键代码: 输出结果: 2.Arrays 类 ...

  2. Auto.js pro 开发环境配置

    本文仅供学习交流使用,如侵立删!demo下载见文末 Auto.js pro 开发环境配置 准备: 1.Auto.js Pro Auto.js 已暂停维护 -下载链接放在了文章底部,有需要自行下载 2. ...

  3. 论文解读(SEP)《Structural Entropy Guided Graph Hierarchical Pooling》

    论文信息 论文标题:Structural Entropy Guided Graph Hierarchical Pooling论文作者:Junran Wu, Xueyuan Chen, Ke Xu, S ...

  4. 刷题记录:Codeforces Round #719 (Div. 3)

    Codeforces Round #719 (Div. 3) 20210703.网址:https://codeforces.com/contest/1520. 没错,我是个做div3的蒟蒻-- A 大 ...

  5. Windows批量修改文件

    如图我是建立了壁纸文件夹 Windows自带的排序方式 如何不用自带的呢? 在这个文件夹里面建一个.txt文件 如下 ok第二步骤 将UTF-8格式改为ANSI格式 点击文件-另存为ANSI格式-替换 ...

  6. SpringMvc(一)-初识

    1.环境搭建 1.1 jar包 <spring.version>4.3.18.RELEASE</spring.version> <!-- spring-mvc begin ...

  7. Linux虚拟机破解密码步骤

    Linux破解密码 重启系统 到达logo界面快速 按 e 编辑当前条目 将光标移至以 linux 开头的行,此为内核命令行 在UTF-8(RHEL7):ro(RHEL8)后添加 rd.break ( ...

  8. 使用STM32控制TMC5160驱动步进电机

    首先先来了解一下TMC5160的3种工作模式 TMC5160通过两个引脚来控制它的工作模式:SD_MODE和SPI_MODE. 1.当SD_MODE接地,SPI_MODE拉高,TMC5160即工作在模 ...

  9. HTTP2指纹识别(一种相对不为人知的网络指纹识别方法)

    这是关于网络指纹识别的两部分系列的第二部分 上一部分我介绍了有关TLS 指纹识别方法(以及在不同客户端的指纹有何区别): https://mp.weixin.qq.com/s/BvotXrFXwYvG ...

  10. PostgreSQL 修改执行计划 GroupAggregate 为 HashAggregate

    1.前言 PostgreSQL 聚合算法有两种,HashAggregate and GroupAggregate .我们知道GroupAggregate 需要对记录进行排序,而 HashAggrega ...