树状数组套trie 模板
求区间排名,第K大,单点修改,区间前驱,区间后驱。
时间复杂度O(logn^3)
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define BASE (int)1e8
#define MAXN 50010
#define MAXNLOG 28
const int MAXNNODE=MAXN*16*MAXNLOG+MAXN;
int n,m,a[MAXNNODE];
namespace trie
{
int ch[MAXNNODE][2],siz[MAXNNODE],id=MAXN;
inline int lowbit(int x){return x&-x;}
inline int insert(int pos,int val,int d=1)
{
val+=BASE;
bool v;
for(int i=MAXNLOG-1;~i;i--)
{
v=(val>>i)&1;
if(!ch[pos][v]) ch[pos][v]=++id;
pos=ch[pos][v];
siz[pos]+=d;
}
}
inline int nlt(int pos,int val)
{
val+=BASE;
int ans=0; bool v;
for(int i=MAXNLOG-1;~i;i--)
{
v=(val>>i)&1;
if(v) ans+=siz[ch[pos][0]];
pos=ch[pos][v];
}
return ans;
}
inline int add(int pos,int val,int d=1)
{
for(;pos<=n;pos+=lowbit(pos))
insert(pos,val,d);
}
inline int query(int pos,int val)
{
int ans=0;
for(;pos>=1;pos-=lowbit(pos)) ans+=nlt(pos,val);
return ans;
}
inline int rnk(int l,int r,int k){return query(r,k)-query(l-1,k)+1;}
inline int kth(int l,int r,int k)
{
int ll=-BASE-1,rr=BASE;
while(ll<rr)
{
int mid=(ll+rr)>>1;
if(rnk(l,r,mid)>k) rr=mid;
else ll=mid+1;
}
return ll-1;
}
}
using namespace std;
using namespace trie;
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++) scanf("%d",&a[i]),trie::add(i,a[i]);
for(int i=1;i<=m;i++)
{
int cur,l,r,x;
scanf("%d",&cur);
if(cur==1) scanf("%d%d%d",&l,&r,&x),printf("%d\n",trie::rnk(l,r,x));
else if(cur==2) scanf("%d%d%d",&l,&r,&x),printf("%d\n",trie::kth(l,r,x));
else if(cur==3) scanf("%d%d",&l,&x),trie::add(l,a[l],-1),a[l]=x,trie::add(l,x);
else if(cur==4) scanf("%d%d%d",&l,&r,&x),printf("%d\n",trie::kth(l,r,rnk(l,r,x)-1));
else if(cur==5) scanf("%d%d%d",&l,&r,&x),printf("%d\n",trie::kth(l,r,rnk(l,r,x+1)));
}
return 0;
}
树状数组套trie 模板的更多相关文章
- bzoj3196 二逼平衡树 树状数组套线段树
题目传送门 思路:树状数组套线段树模板题. 什么是树状数组套线段树,普通的树状数组每个点都是一个权值,而这里的树状数组每个点都是一颗权值线段树,我们用前缀差分的方法求得每个区间的各种信息, 其实关键就 ...
- 2019南昌网络赛 I. Yukino With Subinterval 树状数组套线段树
I. Yukino With Subinterval 题目链接: Problem Descripe Yukino has an array \(a_1, a_2 \cdots a_n\). As a ...
- LUOGU P2617 Dynamic Rankings(树状数组套主席树)
传送门 解题思路 动态区间第\(k\)大,树状数组套主席树模板.树状数组的每个位置的意思的是每棵主席树的根,维护的是一个前缀和.然后询问的时候\(log\)个点一起做前缀和,一起移动.时空复杂度\(O ...
- BZOJ 3196 Tyvj 1730 二逼平衡树 ——树状数组套主席树
[题目分析] 听说是树套树.(雾) 怒写树状数组套主席树,然后就Rank1了.23333 单点修改,区间查询+k大数查询=树状数组套主席树. [代码] #include <cstdio> ...
- 【树状数组套权值线段树】bzoj1901 Zju2112 Dynamic Rankings
谁再管这玩意叫树状数组套主席树我跟谁急 明明就是树状数组的每个结点维护一棵动态开结点的权值线段树而已 好吧,其实只有一个指针,指向该结点的权值线段树的当前结点 每次查询之前,要让指针指向根结点 不同结 ...
- BZOJ 1901 Zju2112 Dynamic Rankings ——树状数组套主席树
[题目分析] BZOJ这个题目抄的挺霸气. 主席树是第一时间想到的,但是修改又很麻烦. 看了别人的题解,原来还是可以用均摊的思想,用树状数组套主席树. 学到了新的姿势,2333o(* ̄▽ ̄*)ブ [代 ...
- 【BZOJ-1452】Count 树状数组 套 树状数组
1452: [JSOI2009]Count Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1769 Solved: 1059[Submit][Stat ...
- 【BZOJ】1901: Zju2112 Dynamic Rankings(区间第k小+树状数组套主席树)
http://www.lydsy.com/JudgeOnline/problem.php?id=1901 首先还是吐槽时间,我在zoj交无限tle啊!!!!!!!!我一直以为是程序错了啊啊啊啊啊啊. ...
- BZOJ1901 - Dynamic Rankings(树状数组套主席树)
题目大意 给定一个有N个数字的序列,然后又m个指令,指令种类只有两种,形式如下: Q l r k 要求你查询区间[l,r]第k小的数是哪个 C i t 要求你把第i个数修改为t 题解 动态的区间第k ...
随机推荐
- MyBatis 学习记录2 Mapper对象是如何生成的
主题 以前我一直有一个问题不懂.并且觉得很神奇.就是Mybatis我们开发的时候只需要定义接口,并没有写实现类,为什么我们运行的时候就可以直接使用? 现在我想分享下这部分大致是怎么实现的. 在启动的时 ...
- 【311】Python 构建 ArcMap 标注表达式
参考:构建标注表达式(官方帮助) 参考:计算字段示例(官方帮助) 说明:以上两者的方法略有不同,一个是通过字段表达式显示标注,一个通过字段计算新的字段,使用的工具方法也不同,前者通过 Layer.la ...
- ThreadLocal原理深入解析
目录 1. 从一次项目经历说起 2. ThreadLocal源码解析 2.1 set方法源码解析 2.2 get方法源码解析 2.3 ThreadLocal源码总结 3. ThreadLocalMap ...
- cardBattle游戏启动场景设计
- Chrome谷歌浏览器屏蔽百度搜索右侧广告推荐方法
先上图百度广告,其实屏蔽广告很简单 主要分成以下三步: 下载Adblock Plus插件 安装Adblock Plus插件 开启屏蔽 一.下载Adblock Plus插件(官网离线版) 二.安装Adb ...
- copy&mutableCopy 浅拷贝(shallow copy)深拷贝 (deep copy)
写在前面 其实看了这么多,总结一个结论: 拷贝的初衷的目的就是为了:修改原来的对象不能影响到拷贝出来得对象 && 修改拷贝出来的对象也不能影响到原来的对象 所以,如果原来对象就是imm ...
- freemaker优缺点
1.什么是FreeMarker?FreeMarker是一个模板引擎,一个基于模板生成文本输出的通用工具,使用纯Java编写.FreeMarker被设计用来生成HTMLWeb页面,特别是基于MVC模式的 ...
- Linux ftp Command
一.ftp的get命令和mget命令有何不同? get一次只下载一个文件:mget一次可以下载多个文件,而且支持通配符,需要注意的是在mget的时侯,需要对每一个文件都选择y/n,如果想不交互的下载全 ...
- code1047 邮票面值设计
dfs+dp dfs枚举每种情况,每层递归确定第k个数i:i = a[k-1]+1 to a[k-1]*n+1 当枚举完一个序列时,使用check()测试它能达到的max 使用dp.设dp[i]为凑成 ...
- Python监控日志程序-乾颐堂
一个简易的日志监控的脚本,功能如下:1.windows环境2.当匹配日志关键字时会发出声音,匹配的关键字不同,播放的声音不同3.能做到实时响应 注意:是在win环境下哦 直接上代码吧 1 2 3 4 ...