POJ2104 K-th number (整体二分)
刚学了整体二分,用这种解法来解决这道题。
首先对于每个询问时可以二分解决的,这也是可以使用整体二分的前提。将原来的序列看成是插入操作,和询问操作和在一起根据值域进行二分。用树状数组来检验二分值。
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 (整体二分)的更多相关文章
- POJ2104 K-th Number [整体二分]
题目传送门 K-th Number Time Limit: 20000MS Memory Limit: 65536K Total Submissions: 69053 Accepted: 24 ...
- POJ2104 K-th Number(整体二分)
题解 又一次做这个题上一次用的是线段树上二分.这次用的是整体二分.结果: (第一个是整体二分) 整体二分就是对于所有查询都二分一个值.然后根据能不能成立把询问修改分成两部分,然后第二部分继承第一部分的 ...
- BZOJ 3110: [Zjoi2013]K大数查询 [整体二分]
有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数是多少. N ...
- BZOJ3110:[ZJOI2013]K大数查询(整体二分)
Description 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c.如果是2 a b c形式,表示询问从第a个位置到第b个位 ...
- BZOJ 3110 K大数查询 | 整体二分
BZOJ 3110 K大数查询 题面 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c 如果是2 a b c形式,表示询问从第a个 ...
- BZOJ.3110.[ZJOI2013]K大数查询(整体二分 树状数组/线段树)
题目链接 BZOJ 洛谷 整体二分求的是第K小(利用树状数组).求第K大可以转为求第\(n-K+1\)小,但是这样好像得求一个\(n\). 注意到所有数的绝对值\(\leq N\),将所有数的大小关系 ...
- 【BZOJ-3110】K大数查询 整体二分 + 线段树
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6265 Solved: 2060[Submit][Sta ...
- 静态区间第K小(整体二分、主席树)
题目链接 题解 主席树入门题 但是这里给出整体二分解法 整体二分顾名思义是把所有操作放在一起二分 想想,如果求\([1-n]\)的第\(k\)小怎么二分求得? 我们可以二分答案\(k\), \(O(n ...
- ZOJ 1112 Dynamic Rankings【动态区间第K大,整体二分】
题目链接: http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1112 题意: 求动态区间第K大. 分析: 把修改操作看成删除与增加 ...
- [ZJOI2013]K大数查询——整体二分
题目描述 有N个位置,M个操作.操作有两种,每次操作如果是: 1 a b c:表示在第a个位置到第b个位置,每个位置加上一个数c 2 a b c:表示询问从第a个位置到第b个位置,第C大的数是多少. ...
随机推荐
- ZooKeeper3.4.10集群安装配置-Docker
一. 服务器规划 主机 IP 端口 备注 b-mid-24 172.16.0.24 2181, 2888, 3888 2181:对cline端提供服务 3888:选举leader使用 2888:集群内 ...
- python打开文件、文件夹窗口、终端窗口
简介 在一些项目中,我们会需要在生成完文件后打开某些文件或者文件夹窗口,这就需要使用到内置的文件打开方式了. 打开文件或文件夹 Windows import os import subprocess ...
- Shell 编程基础语法
# shell脚本 # 如何运行shell脚本 sh test.sh source test.sh ./test.sh # 需要有执行权限 # source和其他两种的区别是.source不会开新进程 ...
- 5.25 NOI 模拟
\(T1\)旅行计划 不\(sb\)的题 比较显然转化成求一个点到所有点的最短路和 考虑我们非树边很少,那么可以把非树边连接的点看做是关键点,那么我们可以预处理每个关键点之间的最短路 我们每次询问,对 ...
- Luogu1868 饥饿的奶牛 (动态规划)
开始以为是贪心,10分:想了个DP估计会超时,一翻题解各路初中神仙,背包都有. \(n^2\)很好想,考虑单调性用二分优化出log #include <iostream> #include ...
- 解决使用 Eruda 绑定 dom 未在指定位置显示问题
前言 开发项目中,使用到 Eruda 打印控制台信息显示 文档:https://github.com/liriliri/eruda 安装 Eruda npm install eruda --save ...
- 记录一个i变量引发的事故
概述 近期开发中遇到一个特别的问题,觉得很有必要与你下来.就是由于在开发中一个很小的疏忽,导致了很大的问题,是什么呢? 现象 我的程序突然引发了v8内部的错误,提示都是c++的,如下.程序一启动就直接 ...
- Dart 异步编程(二):async/await
对每一个异步任务返回的 Future 对象都使用链式操作-- then ,超过三个以上时,导致"倒三角"现象,降低代码的可阅读性. getHobbies() { post('htt ...
- HMS Core Discovery第17期直播预告|音随我动,秒变音色造型师
[导读] 随着音视频内容品类的不断丰富及音乐创作门槛不断降低,大量用户正热切的参与到全民创作的大潮中.我们应该怎么去拥抱移动端影音潜力市场?音频编辑又可以有什么新玩法? 本期直播<音随我动,秒变 ...
- CVE-2021-3156 sudo提权复现
直接查看https://www.bilibili.com/video/BV1Gp4y1s7dd/,已发至B站