【题目分析】

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

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

【代码】

#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. Android studio 自定义打包APK名称

    Android Studio打包应用默认生成的apk名称是:app-release.apk .如果我们要让生成的apk名跟我们版本包名有联系的话,那我们就要自定义生成的apk名了,要怎么做呢. 我们只 ...

  2. 【leetcode】Surrounded Regions(middle)☆

    Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'. A region is captured ...

  3. 真机测试无缘无故finish了。程序也没有启动

    去钥匙串里边把多余的证书删除, 然后reset xcode - preference - 选中你的appleID - iOS Development  -  reset

  4. increadbuild重装

    客户端和服务端都重装,可能需要去任务管理其中停止相关的服务,重装之前要去注册表中删除旧的注册表项.一般情况下incredibuild对应的位置是:64位系统HKEY_CLASSES_ROOT\\Wow ...

  5. C++静态代码分析工具对比cppCheck与PreFast

    具体内容参看文件<CppCheck和PreFast对Cplusplus代码静态分析测试.zip> C++测试源代码main.cpp #define NULL 0 #include < ...

  6. VB.NET 注册表基本操作

    ''' <summary> ''' 注册表设置值 ''' </summary> ''' <param name="strKey"></pa ...

  7. 转载_虚拟机下LInux(终端)配置网络的方法

    出自: http://www.360doc.com/content/14/1027/11/17496895_420258403.shtml 对文章的重点进行剪贴,方便查看. 这几天在虚拟机vmware ...

  8. printf 与c的基本类型之间的关系

    型 書式 注意事項 ssize_t %zd size_t %zu intmax_t %jd uintmax_t %ju ptrdiff_t %t signed char %hhd unsigned c ...

  9. poj1611(并查集)

    题目链接:http://poj.org/problem?id=1611 题意: SARS(非典型肺炎)传播得非常厉害,其中最有效的办法是隔离那些患病.和患病者接触的人.现在有几个学习小组,每小组有几个 ...

  10. Java之POJO

    转: POJO    一:什么是POJOPOJO的名称有多种,pure old java object .plain ordinary java object 等.按照Martin Fowler的解释 ...