BZOJ 3110 [Zjoi2013]K大数查询 ——整体二分
【题目分析】
整体二分显而易见。
自己YY了一下用树状数组区间修改,区间查询的操作。
又因为一个字母调了一下午。
貌似树状数组并不需要清空,可以用一个指针来维护,可以少一个log
懒得写了。
【代码】
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define maxn 50005
#define inf 0x3f3f3f3f
#define ll long long
ll n,m,cnt=0,tot=0;
struct Bit_Tree{
ll a[maxn],b[maxn];
void add(ll x,ll y,ll z)
{
// cout<<"Add "<<x<<" "<<y<<" "<<z<<endl;
for (ll i=x;i<=n;i+=i&(-i)) b[i]+=z;
for (ll i=y+1;i<=n;i+=i&(-i)) b[i]-=z;
for (ll i=x;i<=n;i+=i&(-i)) a[i]+=(n-x)*z;
for (ll i=y+1;i<=n;i+=i&(-i)) a[i]-=(n-y-1)*z;
}
void init()
{
memset(a,0,sizeof a);
memset(b,0,sizeof b);
}
ll getsum(ll x)
{
ll ret=0,tmp=0;
for (ll i=x;i;i-=i&(-i)) ret+=a[i],tmp+=b[i];
return ret-(n-x-1)*tmp;
}
ll get(ll x,ll y)
{
return getsum(y)-getsum(x-1);
}
}t;
struct data{
ll opt,id;
ll x,y,z;
}q[maxn<<1],q1[maxn<<1],q2[maxn<<1];
ll ans[maxn<<1],tag[maxn<<1];
void solve(ll ql,ll qr,ll l,ll r)
{
// cout<<"solve"<<ql<<" "<<qr<<" "<<l<<" "<<r<<endl;
// cout<<"In Que"<<endl;
if (ql>qr) return;
if (l==r)
{
for (ll i=ql;i<=qr;++i) ans[q[i].id]=l;
return ;
}
ll mid=l+r>>1,p1=0,p2=0,cnt=0;
// cout<<"Mid is "<<mid<<endl;
for (ll i=ql;i<=qr;++i)
{
// cout<<q[i].opt<<" "<<q[i].x<<" "<<q[i].y<<" "<<q[i].z<<" "<<endl;
if (q[i].opt==1)
{
if (q[i].z<=mid)
{
t.add(q[i].x,q[i].y,1);
cnt+=q[i].y-q[i].x+1;
q1[++p1]=q[i];
}
else q2[++p2]=q[i];
}
else
{
ll tmp=t.get(q[i].x,q[i].y);
// cout<<"Tmp is "<<tmp<<endl;
if (q[i].z<=tmp) q1[++p1]=q[i];
else q[i].z-=tmp,q2[++p2]=q[i];
}
}
for (ll i=1;i<=p1;++i)
{
if (q1[i].opt==1) t.add(q1[i].x,q1[i].y,-1);
q[ql+i-1]=q1[i];
}
for (ll i=1;i<=p2;++i) q[ql+p1+i-1]=q2[i];
solve(ql,ql+p1-1,l,mid);
solve(ql+p1,qr,mid+1,r);
}
int main()
{
// freopen("in.txt","r",stdin);
// freopen("wa.txt","w",stdout);
scanf("%lld",&n);
n=maxn-1;
scanf("%lld",&m);
cnt=m;
for (ll i=1;i<=m;++i)
{
scanf("%lld%lld%lld%lld",&q[i].opt,&q[i].x,&q[i].y,&q[i].z);
q[i].id=i;
if (q[i].opt==1) t.add(q[i].x,q[i].y,1);
if (q[i].opt==2)
{
tag[i]=1;
tot=t.get(q[i].x,q[i].y);
q[i].z=tot-q[i].z+1;
}
}
for (ll i=1;i<=m;++i)
if (q[i].opt==1)
t.add(q[i].x,q[i].y,-1);
solve(1,cnt,-inf,inf);
for (ll i=1;i<=m;++i)
if (tag[i])
printf("%lld\n",ans[i]);
}
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大数查询 (整体二分+线段树)
和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][ ...
随机推荐
- Create a new Windows service on windows server2012
netsh http add iplisten ipaddress=0.0.0.0:15901 sc.exe create "FPPService" binPath= " ...
- 取代 Windows Search
windows自带的搜索工具太难用了,总是在你急需的时候提示还没有建立索引,眼皮底下的文件都找不到. 1. everything 适合快速搜索文件名 优点是速度快,非常快,几乎是瞬间就建立好了索引. ...
- ubuntu14.04环境下spyder的安装
在ubuntu14.04系统中,默认在/usr/lib目录下安装了python2.7.6和python3.4.3,在该环境下安装spyder,然后使其链接到python3.4.3. 首先安装为pyth ...
- 负载均衡-基础-一致性哈希算法及java实现
一致性hash算法,参考: http://www.blogjava.net/hello-yun/archive/2012/10/10/389289.html 针对这篇文章,加入了自己的理解,在原有的代 ...
- C#操作日志
首先引用NLog的dll文件 using System.IO; using NLog; -------------------------------------------------------- ...
- react+redux官方实例TODO从最简单的入门(6)-- 完结
通过实现了增-->删-->改-->查,对react结合redux的机制差不多已经了解,那么把剩下的功能一起完成吧 全选 1.声明状态,这个是全选状态 2.action约定 3.red ...
- Java课程设计--山寨版QQ
Java课设要求做一个聊天通讯窗口,索性直接照着QQ撸了一个Demo出来 界面高仿qq,初学JAVA,技术比较渣,不喜勿喷 线程开的比较多性能不是太好,一般电脑开两个客户端聊天就卡卡的 先上图 使用方 ...
- final和包装类
==================================================================================================== ...
- 《PHP中的Math函数》笔记
① abs() 绝对值; ② ceil() 向上取整; ③ floor() 向下取整; ④ fmod() 返回除法的浮点数余数; ⑤ getrandmax() 显示随机数最大的可能值; ⑥ is_fi ...
- 我的bootstrapTable的应用
$(function () { //$('#table').attr("data-url", "/conference/" + location.href.sp ...