【学习笔鸡】整体二分(P2617 Dynamic Rankings)
【学习笔鸡】整体二分(P2617 Dynamic Rankings)
可以解决一些需要树套树才能解决的问题,但要求询问可以离线。
首先要找到一个具有可二分性的东西,比如区间\(k\)大,就很具有二分性。具体流程是这样的:
- 假设当前分治是已知当前分治中的询问的范围是\([l,r]\),现在要进一步确定每个询问的范围。二分一个\(mid={l+r\over 2}\)出来,继续确定当前分治中心中每个询问的答案是大于还是小于\(mid\),若小于\(mid\)就放入左边递归,否则去右边递归。对于修改操作,我们同样地递归。注意对于修改拆分,将一个修改变为-1和+1。需要预处理每个修改前后的值是多少。
- 撤回修改,继续递归
分析复杂度:
- 对于分治操作,每次问题减半,那么就是\(T(n)=2T(\dfrac n 2)+F(n)\),\(F(n)\)是处理当前分治答案的时间复杂度。那么我们只要设计一个好的算法,使得可以在优秀的时间内处理当前层就可以行了。
- 对于每个询问,每个询问被处理都是一条\(\log\)的链
时间复杂度看个人实现,好的实现可以做到\(O(\log n)\)的时间复杂度
建议写的时候和写线段树的递归方法统一。 不知道为啥我这份代码写得这么快,Hong Kong journalist
//@winlere
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std; typedef long long ll;
inline int qr(){
register int ret=0,f=0;
register char c=getchar();
while(c<48||c>57)f|=c==45,c=getchar();
while(c>=48&&c<=57) ret=ret*10+c-48,c=getchar();
return f?-ret:ret;
}
const int maxn=1e5+5;
int sav[maxn<<1],len,n,m,cnt,data[maxn],seg[maxn],ans[maxn];
inline void add(const int&pos,const int&tag){for(int t=pos;t<=len&&t>0;t+=t&-t) seg[t]+=tag;}
inline int que(const int&pos){ int ret=0; for(int t=pos;t>0;t-=t&-t) ret+=seg[t]; return ret; }
struct DATA{int ty,l,r,k; DATA(){ty=l=r=k=0;} DATA(int a,int b,int c,int d){ty=a;l=b;r=c;k=d;}};
vector<DATA> q;
inline void addc(const int&pos,const int&tag){
q.push_back(DATA(0,data[pos],-1,pos));
q.push_back(DATA(0,tag,1,pos));
data[pos]=tag; sav[++cnt]=tag;
}
void divd(const int&l,const int&r,vector<DATA>&ve){
if(l==r||ve.empty()) {for(const auto&t:ve) ans[t.ty]=l; return;}
vector<DATA> lef,rgt;
int mid=(l+r)>>1,temp;
for(auto&t:ve)
if(!t.ty)
if(t.l<=mid) add(t.k,t.r),lef.push_back(t);
else rgt.push_back(t);
else
if((temp=que(t.r)-que(t.l-1))>=t.k) lef.push_back(t);
else t.k-=temp,rgt.push_back(t);
for(auto&t:lef) if(!t.ty) add(t.k,-t.r);
divd(l,mid,lef); divd(mid+1,r,rgt);
}
int main(){
n=qr(); m=qr();
memset(data,-1,sizeof data);
for(int t=1;t<=n;++t) q.push_back(DATA(0,sav[++cnt]=data[t]=qr(),1,t));
for(int t=1,t1,t2,t3;t<=m;++t) {
static char c[20];
scanf("%s",c+1);
if(c[1]=='C') t1=qr(),t2=qr(),addc(t1,t2);
if(c[1]=='Q') t1=qr(),t2=qr(),t3=qr(),q.push_back(DATA(t,t1,t2,t3));
}
sort(sav+1,sav+cnt+1);
len=unique(sav+1,sav+cnt+1)-sav-1;
for(auto&t:q)
if(!t.ty)
t.l=lower_bound(sav+1,sav+len+1,t.l)-sav;
divd(1,len,q);
for(int t=1;t<=m;++t) if(ans[t]) printf("%d\n",sav[ans[t]]);
return 0;
}
【学习笔鸡】整体二分(P2617 Dynamic Rankings)的更多相关文章
- 2018.07.01洛谷P2617 Dynamic Rankings(带修主席树)
P2617 Dynamic Rankings 题目描述 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1],a[i ...
- 洛谷P2617 Dynamic Rankings (主席树)
洛谷P2617 Dynamic Rankings 题目描述 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1],a ...
- 洛谷 P2617 Dynamic Rankings 解题报告
P2617 Dynamic Rankings 题目描述 给定一个含有\(n\)个数的序列\(a[1],a[2],a[3],\dots,a[n]\),程序必须回答这样的询问:对于给定的\(i,j,k\) ...
- P2617 Dynamic Rankings(树状数组套主席树)
P2617 Dynamic Rankings 单点修改,区间查询第k大 当然是无脑树套树了~ 树状数组套主席树就好辣 #include<iostream> #include<cstd ...
- 【学习笔鸡】快速沃尔什变换FWT
[学习笔鸡]快速沃尔什变换FWT OR的FWT 快速解决: \[ C[i]=\sum_{j|k=i} A[j]B[k] \] FWT使得我们 \[ FWT(C)=FWT(A)*FWT(B) \] 其中 ...
- Luogu P2617 Dynamic Rankings(整体二分)
题目 动态区间第K小模板题. 一个非常可行的办法是BIT套动态开点权值SegTree,但是它跑的实在太慢了. 然后由于这题并没有强制在线,所以我们可以使用整体二分来吊打树套树. 当然如果强制在线的话就 ...
- 洛谷$P2617\ Dynamic\ Rankings$ 整体二分
正解:整体二分 解题报告: 传送门$w$ 阿查询带修区间第$k$小不显然整体二分板子呗,,, 就考虑先按时间戳排序(,,,其实并不需要读入的时候就按着时间戳排的鸭$QwQ$ 每次二分出$mid$先把所 ...
- 洛谷P2617 Dynamic Rankings
带修主席树模板题 主席树的单点修改就是把前缀和(大概)的形式改成用树状数组维护,每个树状数组的元素都套了一个主席树(相当于每个数组的元素root[i]都是主席树,且这个主席树维护了(i - lowbi ...
- P2617 Dynamic Rankings
题目描述 给定一个含有n个数的序列a[1],a[2],a[3]……a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1],a[i+2]……a[j]中第k小的数是多少(1≤k≤ ...
随机推荐
- 12-3 DOM操作
一 DOM基础 1 DOM介绍 DOM:文档对象模型.DOM 为文档提供了结构化表示,并定义了如何通过脚本来访问文档结构.目的其实就是为了能让js操作html元素而制定的一个规范. DOM就是由节点组 ...
- 谷歌BERT预训练源码解析(三):训练过程
目录前言源码解析主函数自定义模型遮蔽词预测下一句预测规范化数据集前言本部分介绍BERT训练过程,BERT模型训练过程是在自己的TPU上进行的,这部分我没做过研究所以不做深入探讨.BERT针对两个任务同 ...
- day7_python之面向对象高级-反射
反射:通过字符串去找到真实的属性,然后去进行操作 python面向对象中的反射:通过字符串的形式操作对象相关的属性.python中的一切事物都是对象(都可以使用反射) 1.两种方法访问对象的属性 cl ...
- hdu 5742 It's All In The Mind(2016多校第二场)
It's All In The Mind Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Oth ...
- H3C 星型以太网拓扑扩展
- 横向tab计算滚动位置
React横向滚动计算 class Footer extends React.Component { handleClick(e) { const offset = 150; // 指定偏移量 thi ...
- Python--day19--collections模块
常用模块一的各个模块解释: 文件名不要起跟模块名一样:(模块本身就是一个py文件) collection模块: namedtuple方法: 例1: 例2: dequeue方法:双端队列 有序字典Ord ...
- Laravel修改配置后一定要清理缓存 "php artisan config:clear"!
用laravel踩到一个大坑... 需要使用laravel的队列(queue)功能, 设置 ".env"配置文件 QUEUE_DRIVER=database 按照文档,建立jobs ...
- layer/layui弹出层插件bug
<button class="layui-btn" lay-submit lay-filter="formDemo" id="layui-btn ...
- SpringBoot+Thyemleaf开发环境正常,打包jar发到服务器就报错Template might not exist or might not be accessible
网上查看了各种解决的思路,总结如下: 1. 在controller层请求处理完了返回时,没有使用@RestController或@ResponseBody而返回了非json格式 这种情况下返回的数据t ...