【题目分析】

上次用树状数组套主席树做的,这次用整体二分去水。

把所有的查询的结果一起进行二分,思路很好。

【代码】

#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>

#include <set>
#include <map>
#include <string>
#include <algorithm>
#include <vector>
#include <iostream>
#include <queue>
using namespace std;

#define maxn 100005
#define inf (0x3f3f3f3f)

int read()
{
    int x=0,f=1; char ch=getchar();
    while (ch<'0'||ch>'9') {if (ch=='-') f=-1; ch=getchar();}
    while (ch>='0'&&ch<='9') {x=x*10+ch-'0'; ch=getchar();}
    return x*f;
}

struct node{
    int x,y,k;
    int id,opt;
    void print() {
        printf("%d %d %d %d %d\n", x, y, k, id, opt);
    }
}now;

int n,m,a[maxn],ans[maxn];
char s[15];
node q[maxn<<1],q1[maxn],q2[maxn];
int cnt=0,bit[maxn<<1],tot=0;

void add(int x,int f)
{
//  printf("add %d %d\n",x,f);
    for (;x<=n;x+=x&-x) bit[x]+=f;
}

int sum(int x)
{
    int ret=0;
//  printf("sum %d ",x);
    for (;x;x-=x&-x) ret+=bit[x];
//  printf("is %d\n",x,ret);
    return ret;
}

void solve(int ql,int qr,int l,int r)
{
//  printf("solve %d %d %d %d\n",ql,qr,l,r);
    if (ql>qr) return ;
    if (l==r)
    {
        for (int i=ql;i<=qr;++i)
            if (q[i].opt==2) ans[q[i].id]=l;
        return;
    }
    int mid=l+r>>1,p1=0,p2=0;
    for (int i=ql;i<=qr;++i)
    {
        if (q[i].opt==1)
        {
            if (q[i].x<=mid)
            {
                add(q[i].id,q[i].y);
                q1[++p1]=q[i];
            }
            else q2[++p2]=q[i];
        }
        else
        {
            int tmp=sum(q[i].y)-sum(q[i].x-1);
//          printf("tmp is %d\n");
            if (q[i].k<=tmp) q1[++p1]=q[i];
            else
            {
//              cout<<q[i].x<<" "<<q[i].y<<"goto r "<<endl;
                q[i].k-=tmp;
                q2[++p2]=q[i];
            }
        }
    }
    for (int i=1;i<=p1;++i)
        if (q1[i].opt==1)
            add(q1[i].id,-q1[i].y);
    for (int i=1;i<=p1;++i) q[ql+i-1]=q1[i];
    for (int i=1;i<=p2;++i) q[ql+p1+i-1]=q2[i];
//  getchar();
    solve(ql,ql+p1-1,l,mid);
    solve(ql+p1,qr,mid+1,r);
}

int main()
{
    n=read();m=read();
    for (int i=1;i<=n;++i)
    {
        a[i]=now.x=read();now.y=1;now.k=inf;
        now.id=i; now.opt=1;
        q[++cnt]=now;
    }
    for (int i=1;i<=m;++i)
    {
        scanf("%s",s);
        if (s[0]=='Q')
        {
            now.x=read();now.y=read();now.k=read();
            now.id=++tot;now.opt=2;
            q[++cnt]=now;
        }
        else
        {
            int xx=read();
            now.x=a[xx];now.y=-1;now.k=inf;now.id=xx;now.opt=1;
            q[++cnt]=now;
            a[xx]=read();
            now.x=a[xx];now.y=1;now.k=inf;now.id=xx;now.opt=1;
            q[++cnt]=now;
        }
    }
//  for (int i=1;i<=cnt;++i) q[i].print();
    solve(1,cnt,0,inf);
    for (int i=1;i<=tot;++i) printf("%d\n",ans[i]);
}

  

BZOJ 1901 Zju2112 Dynamic Rankings ——整体二分的更多相关文章

  1. bzoj 1901: Zju2112 Dynamic Rankings(树套树)

    1901: Zju2112 Dynamic Rankings 经典的带改动求区间第k小值问题 树套树模板,我是用的线段树套splay实现的,并且用的数组模拟的,所以可能空间略大,bzoj过了,zoj过 ...

  2. Bzoj 1901: Zju2112 Dynamic Rankings 树套树,线段树,平衡树,Treap

    1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 6471  Solved: 2697[Su ...

  3. BZOJ 1901: Zju2112 Dynamic Rankings( BIT 套 BST )

    BIT 套 splay 其实也是不难...每个 BIT 的结点保存一颗 splay , 询问就二分答案然后判断rank... ------------------------------------- ...

  4. BZOJ 1901 Zju2112 Dynamic Rankings

    树阵主席设置树.维护间隔动态K大. .. ZOJ到空间太小,太大,仅仅能到BZOJ上交 1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec  Memor ...

  5. BZOJ 1901: Zju2112 Dynamic Rankings[带修改的主席树]【学习笔记】

    1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 7143  Solved: 2968[Su ...

  6. Bzoj 1901: Zju2112 Dynamic Rankings 主席树,可持久,树状数组,离散化

    1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 6321  Solved: 2628[Su ...

  7. BZOJ 1901: Zju2112 Dynamic Rankings( 树状数组套主席树 )

    裸的带修改主席树.. 之前用BIT套Splay( http://www.cnblogs.com/JSZX11556/p/4625552.html )A过..但是还是线段树好写...而且快(常数比平衡树 ...

  8. bzoj 1901: Zju2112 Dynamic Rankings -- 主席树,树状数组,哈希

    1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec  Memory Limit: 128 MB Description 给定一个含有n个数的序列a[1] ...

  9. bzoj 1901: Zju2112 Dynamic Rankings【整体二分+树状数组||主席树+树状数组】

    整体二分: 对于每一个修改操作,标记为1,并且加一个标记为-1的这个位置原来值,并且对于a数列每个点都当成修改操作 然后整体二分,扫当前操作区间lr,把在值域区间标记为1和-1的操作都在树状数组对应位 ...

随机推荐

  1. 【leetcode】Repeated DNA Sequences(middle)★

    All DNA is composed of a series of nucleotides abbreviated as A, C, G, and T, for example: "ACG ...

  2. ios二维码生成

    二维码扫描现在已经有很多的库可以使用了,常用的有ZXing和ZBar.如果感兴趣的同学可以自行研究. libqrencode介绍:是一个用C语言编写的用来解析二维条形码(QR Code)的程序库,li ...

  3. cuda编程基础

    转自: http://blog.csdn.net/augusdi/article/details/12529247 CUDA编程模型 CUDA编程模型将CPU作为主机,GPU作为协处理器(co-pro ...

  4. 如何解决exe4j生成exe文件后弹出提示信息

    使用exe4j生成exe文件时会提示以上一段信息,这个主要是没有注册导致的,在welcome to exe4j的右下角有一个注册信息的地方,去找个注册码,就OK了. 通用注册码:L-g782dn2d- ...

  5. EF增删改查基础

    #region 1.0 新增 -void Add() /// <summary> /// 1.0 新增 /// </summary> static void Add() { / ...

  6. 兼容iOS 10:配置获取隐私数据权限声明

    原文链接 iOS 10的一大变化是更强的隐私数据保护.在文档中是这么描述的: You must statically declare your app’s intended use of protec ...

  7. HTML5学习之WebSocket通讯(六)

    WebSocket是下一代客户端-服务器的异步通信方法. WebSocket最伟大之处在于服务器和客户端可以在任意时刻相互推送信息 WebSocket允许跨域通信 Ajax技术需要客户端发起请求,We ...

  8. sdut1598 周游列国【简单模拟题】

    周游列国 Time Limit: 1000ms   Memory limit: 32768K  有疑问?点这里^_^ 题目描述 题目链接:http://acm.sdut.edu.cn/sdutoj/p ...

  9. [LeetCode] Happy Number

    Happy Number Total Accepted: 35195 Total Submissions: 106936 Difficulty: Easy Write an algorithm to ...

  10. sqlplus 中spool命令的简单用法

    spool基本格式: spool 路径+文件名 select col1||','||col2||','||col3||','||col4||'..' from tablename; spool off ...