【BZOJ 3110】 [Zjoi2013]K大数查询(整体二分)
【题目】
Description
有N个位置,M个操作。操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c
如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数是多少。Input
第一行N,M
接下来M行,每行形如1 a b c或2 a b cOutput
输出每个询问的结果
Sample Input
2 5
1 1 2 1
1 1 2 2
2 1 1 2
2 1 1 1
2 1 2 3Sample Output
1
2
1HINT
【样例说明】
第一个操作 后位置 1 的数只有 1 , 位置 2 的数也只有 1 。 第二个操作 后位置 1
的数有 1 、 2 ,位置 2 的数也有 1 、 2 。 第三次询问 位置 1 到位置 1 第 2 大的数 是
1 。 第四次询问 位置 1 到位置 1 第 1 大的数是 2 。 第五次询问 位置 1 到位置 2 第 3
大的数是 1 。
N,M<=50000,N,M<=50000
a<=b<=N
1操作中abs(c)<=N
2操作中c<=Maxlongint
用solve(l,r,S)表示现在处理S集合,S集合是操作集合按照时间排序,所有插入操作满足插入的球数值在l~r,所有询问操作满足其答案在区间l~r。
每个询问操作需要保存一个cnt代表目前在其询问的对应区间内>r的有多少个。
然后我们按顺序扫描操作。先记mid=(l+r)/2
对于插入操作,如果其插入的球数值>mid那么我们将对应区间加1(用线段树维护区间内mid+1~r的球个数)。然后根据其数值让其进入l~mid或mid+1~r。
对于询问操作,我们得到其区间内数值为mid+1~r的个数j,然后如果j+cnt<=k-1那么显然mid不可能是该询问的答案,将该询问进入l~mid并更新其的cnt否则进入mid+1~r。
然后做到l=r的时候就可以解决所有进入此区间的询问。
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
#define INF 0xfffffff
#define Maxn 50010
#define LL long long struct work
{
LL l,r,c,p,ans;
}t[Maxn]; LL a[Maxn],a1[Maxn],a2[Maxn],ans[Maxn];
LL n,m; LL c1[Maxn],c2[Maxn];
void add(LL l,LL r,LL c)
{
// printf("add %d %d %d\n",l,r,c);
for(LL i=l;i<=n;i+=i&(-i))
c1[i]+=c,c2[i]+=l*c;
r++;
for(LL i=r;i<=n;i+=i&(-i))
c1[i]-=c,c2[i]-=r*c;
} LL query(LL l,LL r)
{
// printf("ask %d %d ",l,r);
LL ans=;
for(LL i=r;i>=;i-=i&(-i))
ans+=c1[i]*(r+)-c2[i];
l--;
for(LL i=l;i>=;i-=i&(-i))
ans-=c1[i]*(l+)-c2[i];
// printf("%d\n",ans);
return ans;
} void solve(LL x,LL y,LL l,LL r)
{
if(l==r)
{
for(LL i=x;i<=y;i++) if(t[a[i]].p==) t[a[i]].ans=l;
return;
}
LL mid=(l+r)>>;
a1[]=;a2[]=;
for(LL i=x;i<=y;i++)
{
if(t[a[i]].p==)
{
if(t[a[i]].c<=mid) a1[++a1[]]=a[i];
else a2[++a2[]]=a[i],add(t[a[i]].l,t[a[i]].r,);
}
else
{
LL now=query(t[a[i]].l,t[a[i]].r);
if(now>=t[a[i]].c) a2[++a2[]]=a[i];
else a1[++a1[]]=a[i],t[a[i]].c-=now;
}
}
for(LL i=x;i<=y;i++) if(t[a[i]].p==&&t[a[i]].c>mid) add(t[a[i]].l,t[a[i]].r,-);
LL ll=a1[],rr=a2[];
for(LL i=;i<=ll;i++) a[x+i-]=a1[i];
for(LL i=;i<=rr;i++) a[x+ll+i-]=a2[i];
solve(x,x+ll-,l,mid);
solve(x+ll,x+ll+rr-,mid+,r);
} void init()
{
scanf("%lld%lld",&n,&m);
for(LL i=;i<=m;i++)
{
scanf("%lld%lld%lld%lld",&t[i].p,&t[i].l,&t[i].r,&t[i].c);
}
memset(c1,,sizeof(c1));
memset(c2,,sizeof(c2));
for(LL i=;i<=m;i++) a[i]=i;
solve(,m,,n);
} int main()
{
init();
for(LL i=;i<=m;i++) if(t[i].p==) printf("%lld\n",t[i].ans);
return ;
}
2016-11-09 13:46:58
【BZOJ 3110】 [Zjoi2013]K大数查询(整体二分)的更多相关文章
- BZOJ.3110.[ZJOI2013]K大数查询(整体二分 树状数组/线段树)
题目链接 BZOJ 洛谷 整体二分求的是第K小(利用树状数组).求第K大可以转为求第\(n-K+1\)小,但是这样好像得求一个\(n\). 注意到所有数的绝对值\(\leq N\),将所有数的大小关系 ...
- BZOJ 3110: [Zjoi2013]K大数查询 [整体二分]
有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数是多少. N ...
- BZOJ 3110 [Zjoi2013]K大数查询 ——整体二分
[题目分析] 整体二分显而易见. 自己YY了一下用树状数组区间修改,区间查询的操作. 又因为一个字母调了一下午. 貌似树状数组并不需要清空,可以用一个指针来维护,可以少一个log 懒得写了. [代码] ...
- BZOJ 3110 [ZJOI2013]K大数查询 (整体二分+线段树)
和dynamic rankings这道题的思想一样 只不过是把树状数组换成线段树区间修改,求第$K$大的而不是第$K$小的 这道题还有负数,需要离散 #include <vector> # ...
- BZOJ 3110 [Zjoi2013]K大数查询(整体二分)
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 11654 Solved: 3505[Submit][St ...
- BZOJ 3110: [Zjoi2013]K大数查询 [树套树]
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6050 Solved: 2007[Submit][Sta ...
- bzoj 3110: [Zjoi2013]K大数查询 树状数组套线段树
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1384 Solved: 629[Submit][Stat ...
- 树套树专题——bzoj 3110: [Zjoi2013] K大数查询 & 3236 [Ahoi2013] 作业 题解
[原题1] 3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MB Submit: 978 Solved: 476 Descri ...
- BZOJ 3110: [Zjoi2013]K大数查询( 树状数组套主席树 )
BIT+(可持久化)权值线段树, 用到了BIT的差分技巧. 时间复杂度O(Nlog^2(N)) ---------------------------------------------------- ...
- BZOJ 3110([Zjoi2013]K大数查询-区间第k大[段修改,在线]-树状数组套函数式线段树)
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MB Submit: 418 Solved: 235 [ Submit][ ...
随机推荐
- LUN 和 LVM 知识
LUN是对存储设备而言的,volume是对主机而言的. lun是指硬件层分出的逻辑盘,如raid卡可以将做好的400G的raid5再分成若干个逻辑盘,以便于使用,每一个逻辑盘对应一个lun号,OS层仍 ...
- Apache Commons Beanutils对象属性批量复制(pseudo-singleton)
Apache Commons Beanutils为开源软件,可在Apache官网http://commons.apache.org/proper/commons-beanutils/download_ ...
- Yii框架页面运行流程
Yii框架页面运行流程 CComponent | CModel | CActiveRecord.CFormModel(所有模型的父类) | 表名.php(模型) | 入口文件------------- ...
- 关于使用json 字符串转换为字典问题
问题背景: '{"backend": "www.baidu.org", "record": {"server": &qu ...
- ImageButton 在IE 10 下的异常
最近在项目中遇到一个棘手问题,在IE10中,一些图片按钮点了毫无反应,其他浏览器(包括IE9)都正常:查看后台,发现如下异常信息: Input string was not in a correct ...
- nyoj89 汉诺塔(二)
题目网址 :http://acm.nyist.net/JudgeOnline/problem.php?pid=89 汉诺塔问题的经典结论: 把i个盘子从一个柱子整体移到另一个柱子最少需要步数是 2的i ...
- ZeroMemory
ZeroMemory: 用0填充一个内存块 void ZeroMemory( [in] PVOID Destination, //内存块开始地址 [in] SIZE_T Length //填充块大小 ...
- (一)初识Android
第一节:手机操作系统简介 目前的主流智能操作系统有:Android , IOS , windows mobile ; Android 开源,属于谷歌公司,市场份额较大,前景广阔: IOS 属于苹果公司 ...
- u盘的超级用法
转自360 U盘是大家最常用的移动存储设备,不过它的即插即用特性在给我们带来方便同时,也带来了极大的安全隐患.一款没有加密功能的U盘,在借给他人使用或不慎丢失时,其中所保存的资料将很容 ...
- 基于注解整合struts2与spring的时候如果不引入struts2-spring-plugin包自动装配无效
基于注解整合struts2与spring的时候如果不引入struts2-spring-plugin包,自动装配将无效,需要spring注入的对象使用时将抛出空指针异常(NullPointerExcep ...