【题目分析】

整体二分显而易见。

自己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大数查询 ——整体二分的更多相关文章

  1. BZOJ.3110.[ZJOI2013]K大数查询(整体二分 树状数组/线段树)

    题目链接 BZOJ 洛谷 整体二分求的是第K小(利用树状数组).求第K大可以转为求第\(n-K+1\)小,但是这样好像得求一个\(n\). 注意到所有数的绝对值\(\leq N\),将所有数的大小关系 ...

  2. BZOJ 3110: [Zjoi2013]K大数查询 [整体二分]

    有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数是多少. N ...

  3. BZOJ 3110 [ZJOI2013]K大数查询 (整体二分+线段树)

    和dynamic rankings这道题的思想一样 只不过是把树状数组换成线段树区间修改,求第$K$大的而不是第$K$小的 这道题还有负数,需要离散 #include <vector> # ...

  4. BZOJ 3110 [Zjoi2013]K大数查询(整体二分)

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 11654  Solved: 3505[Submit][St ...

  5. BZOJ 3110: [Zjoi2013]K大数查询 [树套树]

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6050  Solved: 2007[Submit][Sta ...

  6. bzoj 3110: [Zjoi2013]K大数查询 树状数组套线段树

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 1384  Solved: 629[Submit][Stat ...

  7. 树套树专题——bzoj 3110: [Zjoi2013] K大数查询 &amp; 3236 [Ahoi2013] 作业 题解

    [原题1] 3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MB Submit: 978  Solved: 476 Descri ...

  8. BZOJ 3110: [Zjoi2013]K大数查询( 树状数组套主席树 )

    BIT+(可持久化)权值线段树, 用到了BIT的差分技巧. 时间复杂度O(Nlog^2(N)) ---------------------------------------------------- ...

  9. BZOJ 3110([Zjoi2013]K大数查询-区间第k大[段修改,在线]-树状数组套函数式线段树)

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec   Memory Limit: 512 MB Submit: 418   Solved: 235 [ Submit][ ...

随机推荐

  1. 实战动态PDF在线预览及带签名的PDF文件转换

    开篇语: 最近工作需要做一个借款合同,公司以前的合同都是通过app端下载,然后通过本地打开pdf文件,而喜欢创新的我,心想着为什么不能在线H5预览,正是这个想法,说干就干,实践过程总是艰难的,折腾了3 ...

  2. iptables原理

    1.iptables防火墙简介 Iptables也叫netfilter是Linux下自带的一款免费且优秀的基于包过滤的防火墙工具,它的功能十分强大,使用非常灵活,可以对流入.流出.流经服务器的数据包进 ...

  3. CentOs 6.5 安装Ganglia步骤

    一 . 说明 Ganglia由gmond.gmetad和gweb三部分组成 gmond(Ganglia Monitoring Daemon)是一种轻量级服务,安装在每台需要收集指标数据的节点主机上.g ...

  4. Python中函数、类、模块和包的调用

    初学python阶段,大多数人对函数.类.模块和包的调用都搞得不是很清楚,这篇随笔就简单的进行说明. (1)函数 当函数定义好之后,可以直接调用. 比如:def summ(add1,add2),那么 ...

  5. python中不同包之间调用方法、

    在pycharm中... 当两个py文件在同一个文件夹下的时候.直接from 文件名 import *  即可 当两个文件在不同的文件夹下的时候.需要在文件中加入 _init_.py 文件.里面可以什 ...

  6. URI编码解码

    .NET string s= System.Web.HttpUtility.UrlEncode("123", System.Text.Encoding.Unicode); //编码 ...

  7. winform 跨线程操作控件

    当进行winform的开发时,经常遇到用时比较久的操作,在传统的单线程程序中,用户必须等待这个耗时操作完成以后才能进行下一步的操作,这个时候,多线程编程就派上用场了,将这个耗时的操作放到一个新的子线程 ...

  8. 关于iframe

    iframe一般用来嵌套其他页面来使用 1.如何使用? <iframe id="iframe1" src="2.html" frameborder=&qu ...

  9. 卡特兰数(Catalan)

    卡特兰数又称卡塔兰数,英文名Catalan number,是组合数学中一个常出现在各种计数问题中出现的数列.由以比利时的数学家欧仁·查理·卡塔兰 (1814–1894)命名,其前几项为 : 1, 2, ...

  10. R语言进阶

    一.初学入门:<R in Action><The Art of_R Programming>入门者可首选两本,前者从统计角度入手,分高中低三部分由浅入深的讲解了如何用R来实现统 ...