【BZOJ】【1901】【Zju2112】 Dynamic Rankings
再填个坑。
动态维护区间第K大(带单点修改)
首先裸的区间第K大我们是用的【前缀和】思想,实现O(n)预处理,O(1)找树查询,那么如果是动态的呢?我们可以利用树状数组(BIT)的思想,进行O(logn)的修改,O(logn)的查询(当然由于是在线段树上做,都各需要再乘logn的复杂度)
也就是说,每次修改,一块改logn棵线段树;每次查询也是在logn棵线段树上一起往下找!
P.S.本题需将所有数(包括修改后的数)进行离散化
//BZOJ 1901
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
#define F(i,j,n) for(int i=j;i<=n;++i)
#define D(i,j,n) for(int i=j;i>=n;--i)
#define lowbit(x) ((x)&(-(x)))
using namespace std;
const int N=; struct Tree{
int cnt,l,r;
}t[N*];
int n,m,num=,root[N],a[N>>],b[N],dat[N>>][],size=,cnt=;
int lc,rc,ln[N],rn[N]; #define mid (l+r>>1)
void build(int &o,int l,int r){
o=++cnt; t[o].cnt=;
if (l==r) return;
build(t[o].l,l,mid);
build(t[o].r,mid+,r);
} void updata(int &o,int l,int r,int pos,int val){
t[++cnt]=t[o],o=cnt,t[o].cnt+=val;
if (l==r) return;
if (pos <= mid) updata(t[o].l,l,mid,pos,val);
else updata(t[o].r,mid+,r,pos,val);
} void modify(int x,int pos,int val){
for(x;x<=n;x+=lowbit(x) )//一次改logn棵树
updata(root[x],,num,pos,val);
} int query(int i,int j,int rank){
int l=,r=num;
int tl=,tr=; while(l!=r){
tl=tr=;
F(i,,lc) tl+=t[t[ln[i]].l].cnt;//将logn棵树的和加出来
F(i,,rc) tr+=t[t[rn[i]].l].cnt;
if (tr-tl>=rank){
F(i,,lc) ln[i]=t[ln[i]].l;//向左找
F(i,,rc) rn[i]=t[rn[i]].l;
r=mid;
}
else{
F(i,,lc) ln[i]=t[ln[i]].r;//向右找
F(i,,rc) rn[i]=t[rn[i]].r;
l=mid+; rank-=tr-tl;
} }
return l;
}
#undef mid
int getans(int l,int r,int k){
rc=lc=;
for(r;r;r-=lowbit(r))
rn[++rc]=root[r];
for(l;l;l-=lowbit(l))
ln[++lc]=root[l];
return query(,num,k);
} void solve(){
sort(b+,b+size+);
num=unique(b+,b+size+)-b-;//这个神奇的用法……是什么意思?
F(i,,n) a[i]=lower_bound(b+,b+num+,a[i])-b;
build(root[],,num);
F(i,,n) modify(i,a[i],);
F(i,,m){
if(dat[i][]==) printf("%d\n",b[ getans(dat[i][]-,dat[i][],dat[i][]) ]);
else{
int pos=lower_bound(b+,b+num+,dat[i][])-b;
modify(dat[i][],a[dat[i][]],-);
a[dat[i][]]=pos;
modify(dat[i][],a[dat[i][]],);
}
}
} int main(){
#ifndef ONLINE_JUDGE
freopen("file.in","r",stdin);
#endif
int T=;
// scanf("%d",&T);
while(T--){
size=cnt=num=;
memset(b,,sizeof b);
memset(t,,sizeof t);
memset(dat,,sizeof dat);
scanf("%d%d",&n,&m);
F(i,,n){
scanf("%d",&a[i]);
b[++size]=a[i];
}
char cmd[];
F(i,,m){
scanf("%s",cmd);
if (cmd[]=='C'){
dat[i][]=;
scanf("%d%d",&dat[i][],&dat[i][]);
b[++size]=dat[i][];
}
else{
dat[i][]=;
scanf("%d%d%d",&dat[i][],&dat[i][],&dat[i][]);
}
}
solve();
}
return ;
}
/**************************************************
利用BIT的思想,实现前缀-差分的logn的转化
裸的可持久化线段树是每棵树维护一个区间[1,i](前缀和)
查询O(1),而修改就需要 O(n)了
而动态进行修改&查询-->BIT里套一个可持久化线段树
BIT的每个节点表示原数组的一个区间
然后用可持久化线段树来维护这个区间
查询的时候log(n)棵线段树一起查
**************************************************/
【BZOJ】【1901】【Zju2112】 Dynamic Rankings的更多相关文章
- 【BZOJ 2754 喵星球上的点名】
Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 2512 Solved: 1092[Submit][Status][Discuss] Descript ...
- BZOJ 1901: Zju2112 Dynamic Rankings[带修改的主席树]【学习笔记】
1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 7143 Solved: 2968[Su ...
- 【BZOJ】3052: [wc2013]糖果公园
http://www.lydsy.com/JudgeOnline/problem.php?id=3052 题意:n个带颜色的点(m种),q次询问,每次询问x到y的路径上sum{w[次数]*v[颜色]} ...
- 【BZOJ】3319: 黑白树
http://www.lydsy.com/JudgeOnline/problem.php?id=3319 题意:给一棵n节点的树(n<=1e6),m个操作(m<=1e6),每次操作有两种: ...
- 【BZOJ】3319: 黑白树(并查集+特殊的技巧/-树链剖分+线段树)
http://www.lydsy.com/JudgeOnline/problem.php?id=3319 以为是模板题就复习了下hld............................. 然后n ...
- 【BZOJ】【1025】【SCOI2009】游戏
DP/整数拆分 整个映射关系可以分解成几个循环(置换群的预备知识?),那么总行数就等于各个循环长度的最小公倍数+1(因为有个第一行的1~N).那么有多少种可能的排数就等于问有多少种可能的最小公倍数. ...
- 【BZOJ】1013: [JSOI2008]球形空间产生器sphere
[BZOJ]1013: [JSOI2008]球形空间产生器sphere 题意:给n+1个n维的点的坐标,要你求出一个到这n+1个点距离相等的点的坐标: 思路:高斯消元即第i个点和第i+1个点处理出一个 ...
- 【BZOJ】1002:轮状病毒(基尔霍夫矩阵【附公式推导】或打表)
Description 轮状病毒有很多变种,所有轮状病毒的变种都是从一个轮状基产生的.一个N轮状基由圆环上N个不同的基原子和圆心处一个核原子构成的,2个原子之间的边表示这2个原子之间的信息通道.如下图 ...
- 【BZOJ】【3697】采药人的路径&【3127】【USACO2013 Open】Yin and Yang
点分治 Orz hzwer 倒是比较好想到点分治……然而在方案统计这里,我犯了两个错误…… 1.我比较傻逼的想的是:通过儿子来更新父亲,也就是统计以x为根的子树中xxxx的路径有多少条……这样转移. ...
- 【BZOJ】【3083】遥远的国度
树链剖分/dfs序 其实过了[BZOJ][4034][HAOI2015]T2以后就好搞了…… 链修改+子树查询+换根 其实静态树的换根直接树链剖分就可以搞了…… 因为其实只有一样变了:子树 如果roo ...
随机推荐
- Resources are low on NN. Please add or free up more resources then turn off safe mode manually.
提交spark应用到yarn集群上的时候在跑一段时间就会出现这个报错: 根据上面的报错原因分析是因为集群资源不够,集群的自我保护机制使hdfs处于安全模式,然后我用"hdfs dfsadmi ...
- (转)Java操作Hbase进行建表、删表以及对数据进行增删改查,条件查询
1.搭建环境 新建JAVA项目,添加的包有: 有关Hadoop的hadoop-core-0.20.204.0.jar 有关Hbase的hbase-0.90.4.jar.hbase-0.90.4-tes ...
- android中常用菜单(menu)的基本知识
(一)选项菜单 1.简单的创建菜单: @Override public boolean onCreateOptionsMenu(Menu menu) { super.onCreateOptionsMe ...
- python之文件
文件打开函数:f = open 表1-1:open函数中模式参数常用值 打开模式 描述 'r' 读模式 'w' 写模式 'a' 追加模式 'b' 二进制模式 '+' 读/写模式 表1-2:文件对象方法 ...
- Java jdk环境变量配置
首先安装jdk,现在已经是jdk 8了,也不知道能不能好好用了...
- lnmp的使用
命令 1.状态管理 lnmp {start|stop|reload|restart|kill|status} 2.添加虚拟host lnmp vhost add
- SharePoint 项目的死法(一)
SharePoint是Microsoft的一个巨NB的产品, 从可查到的数据来看, 财富500强中已经有超过80%的企业已经使用了SharePoint的不同版本,从项目实施的经验来看, 个人感觉这个数 ...
- 应聘复习基础笔记1:网络编程之TCP与UDP的优缺点,TCP三次握手、四次挥手、传输窗口控制、存在问题
重要性:必考 一.TCP与UDP的优缺点 ①TCP---传输控制协议,提供的是面向连接.可靠的字节流服务.当客户和服务器彼此交换数据前,必须先在双方之间建立一个TCP连接,之后才能传输数据.TCP提供 ...
- uva 11922 Permutation Transforme/splay tree
原题链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=18902 伸展树的区间翻转剪切... 如下: #include< ...
- 使用ViewSwitcher和ViewFlipper在不同布局中切换
xml布局: <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:androi ...