大视野——3339: Rmq Problem

Time Limit: 20 Sec  Memory Limit: 128 MB
Submit: 1192  Solved: 620
[Submit][Status][Discuss]

Description

Input

Output

Sample Input

7 5
0 2 1 0 1 3 2
1 3
2 3
1 4
3 6
2 7

Sample Output

3
0
3
2
4

HINT

Source

By Xhr

思路:

对于这个题似乎暴力不好打,而且似乎强制在线操作也比较难弄。但是,强制在线操作不好弄,我们来试试离线操作。由于这个题支持离线操作,so,我们来考虑一下离线操作怎么弄。

首先,我们可以这样想,不是要输入一串数嘛,你在输入这些数时进行一个预处理。先预处理出每个数添加进去时从这堆数的开头开始一直到这个是添加进去时,这堆数的mex值。

在预处理这堆数的mex值时,我们可以这样想,对于一个数我们把它加进去,对这堆数的mex值产生什么影响呢?

你可以这样想,如果把这个数填进去使这堆数的mex值变得更小的话,那样的话这个mex在开始的时候就已经使用过的了,这样的话,是不是就说明再添加进一个数的时候,对他的max数产生的影响就是这个数的max数只有可能变大。

在就是在处理的时候,我们要这样来看,对于一堆区间我们要求他的max值,我们该怎样来做呢?

我们先把要求的区间排个序,当然要先存下这堆数的编号,方便以后输出。

我们按照每一个区间左端点排序,每一次都将这整个区间的左端点进行向内缩,直到缩到这个要求的区间为止。

向内进行所点的时候,每索一个,这个点存在两种情况,一.这个点在后面还会再出现那样的话,将这个点去掉以后是不是对以后的区间的max值没有影响啊。 二.这个点在以后没有存在,那下个区间的max值的影响为,若这个点的值比下个区间的max值大那他的max值不发生改变,若这个点的值比下一个区间的max小,那就将下一个区间的max值赋成这个点的值。

对于区间修改的时候,我们可以采用线段树。

代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
#define inf 0x7fffffff
using namespace std;
inline int read()
{
    ;char ch=getchar();
    '){ch=getchar();}
    +ch-';ch=getchar();}
    return x;
}
;
],sg[],ans[],next[],last[];
],rs[],mn[];
];
];
bool cmp(data a,data b)
{return a.l<b.l;}
void build(int k,int l,int r)
{
     ls[k]=l;rs[k]=r;mn[k]=inf;
     if(l==r){mn[k]=sg[l];return;}
     ;
     build(k<<,l,mid);build(k<<|,mid+,r);
}
void pushdown(int k)
{
     int l=ls[k],r=rs[k];
     if(l==r)return;
     mn[k<<]=min(mn[k],mn[k<<]);
     mn[k<<|]=min(mn[k],mn[k<<|]);
}
int ask(int k,int x)
{
    if(mn[k]!=inf)pushdown(k);
    int l=ls[k],r=rs[k];
    if(l==r)return mn[k];
    ;
    ,x);
    |,x);
}
void update(int k,int x,int y,int val)
{
     if(mn[k]!=inf)pushdown(k);
     int l=ls[k],r=rs[k];
     if(l==x&&y==r){mn[k]=min(mn[k],val);return;}
     ;
     ,x,y,val);
     |,x,y,val);
     ,x,mid,val);update(k<<|,mid+,y,val);}
}
int main()
{
    n=read();m=read();
    ;i<=n;i++)
        a[i]=read();
    ;i<=n;i++)
    {
        mark[a[i]]=;
        if(a[i]==k)
            while(mark[k])k++;
        sg[i]=k;
    }
    build(,,n);
    ;i--)
        next[i]=last[a[i]],last[a[i]]=i;
    ;i<=m;i++)
    {
        q[i].l=read();q[i].r=read();
        q[i].id=i;
    }
    sort(q+,q+m+,cmp);
    ;
    ;i<=m;i++)
    {
        while(now<q[i].l)
        {
            ;
            update(,now,next[now]-,a[now]);
            now++;
        }
        ans[q[i].id]=ask(,q[i].r);
    }
    ;i<=m;i++)
        printf("%d\n",ans[i]);
    ;
}

Rmq Problem的更多相关文章

  1. BZOJ 3489: A simple rmq problem

    3489: A simple rmq problem Time Limit: 40 Sec  Memory Limit: 600 MBSubmit: 1594  Solved: 520[Submit] ...

  2. BZOJ3339 Rmq Problem

    [bzoj3339]Rmq Problem Description Input Output Sample Input 7 5 0 2 1 0 1 3 2 1 3 2 3 1 4 3 6 2 7 Sa ...

  3. bzoj 3489: A simple rmq problem k-d树思想大暴力

    3489: A simple rmq problem Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 551  Solved: 170[Submit][ ...

  4. Bzoj 3339: Rmq Problem && Bzoj 3585: mex 莫队,树状数组,二分

    3339: Rmq Problem Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 833  Solved: 397[Submit][Status][D ...

  5. 【Luogu4137】Rmq Problem/mex (莫队)

    [Luogu4137]Rmq Problem/mex (莫队) 题面 洛谷 题解 裸的莫队 暴力跳\(ans\)就能\(AC\) 考虑复杂度有保证的做法 每次计算的时候把数字按照大小也分块 每次就枚举 ...

  6. P4137 Rmq Problem / mex (莫队)

    题目 P4137 Rmq Problem / mex 解析 莫队算法维护mex, 往里添加数的时候,若添加的数等于\(mex\),\(mex\)就不能等于这个值了,就从这个数开始枚举找\(mex\): ...

  7. Codeforces 803G Periodic RMQ Problem 线段树

    Periodic RMQ Problem 动态开点线段树直接搞, 我把它分成两部分, 一部分是原来树上的, 一部分是后来染上去的,两个部分取最小值. 感觉有点难写.. #include<bits ...

  8. 主席树||可持久化线段树+离散化 || 莫队+分块 ||BZOJ 3585: mex || Luogu P4137 Rmq Problem / mex

    题面:Rmq Problem / mex 题解: 先离散化,然后插一堆空白,大体就是如果(对于以a.data<b.data排序后的A)A[i-1].data+1!=A[i].data,则插一个空 ...

  9. 洛谷 P4137 Rmq Problem /mex 解题报告

    P4137 Rmq Problem /mex 题意 给一个长为\(n(\le 10^5)\)的数列\(\{a\}\),有\(m(\le 10^5)\)个询问,每次询问区间的\(mex\) 可以莫队然后 ...

  10. 分块+莫队||BZOJ3339||BZOJ3585||Luogu4137||Rmq Problem / mex

    题面:P4137 Rmq Problem / mex 题解:先莫队排序一波,然后对权值进行分块,找出第一个没有填满的块,直接for一遍找答案. 除了bzoj3339以外,另外两道题Ai范围都是1e9. ...

随机推荐

  1. oracle row_number的使用

    create table studentInfo(  id number(8) primary key,  name varchar2(20) not null,  ObjectName varcha ...

  2. CS193p Lecture 9 - Animation, Autolayout

    Animation(动画) Demo Dropit续 Autolayout(自动布局) 三种添加自动布局的方法: 使用蓝色辅助虚线,右键选择建议约束(Reset to Suggested Constr ...

  3. 初涉树形dp

    算是一个……复习以及进阶? 什么是树形dp 树形dp是一种奇妙的dp…… 它的一个重要拓展是和各种树形的数据结构结合,比如说在trie上.自动机上的dp. 而且有些时候还可以拓展到环加外向树.仙人掌上 ...

  4. mysqldump指令说明

    3种形式mysqldump [OPTIONS] database [tables]mysqldump [OPTIONS] -B | --databases [OPTIONS] DB1 [DB2 DB3 ...

  5. 本地开发环境中部署已经写好的magento2.0项目

    环境:apache2.4.25+php7.0.16+mysql5.7 (注意版本搭配,详细可以看magento2.0官网看配置) apache最好使用80端口,host文件配置本地虚拟域名 php.i ...

  6. perl学习之六:变量作用域

    变量作用域 (一)包变量 $x = 1 这里,$x是个包变量.关于包变量,有2件重要的事情要了解: 1)假如没有其他申明,变量就是包变量:2)包变量总是全局的. 全局意味着包变量在每个程序里总可访问到 ...

  7. (转)automaticallyAdjustsScrollViewInsets(个人认为iOS7中略坑爹的属性)

    转自http://m.blog.csdn.net/blog/humingtao2013/27662093 automaticallyAdjustsScrollViewInsets(个人认为iOS7中略 ...

  8. [转]ARM平台下独占访问指令LDREX和STREX

    参考:ARM平台下独占访问指令LDREX和STREX的原理与使用详解 全文转载如下: 为了实现线程间同步,一般都要在执行关键代码段之前加互斥(Mutex)锁,且在执行完关键代码段之后解锁.为了实现所谓 ...

  9. app启动画面(prepo)

    IPhone启动画面以及图标的设置 目前IPhone的分辨率为:320X480.640X960.640X1136. Default.png                    320X480 iPh ...

  10. Python requests模块params、data、json的区别

    json和dict对比 json的key只能是字符串,python的dict可以是任何可hash对象(hashtable type): json的key可以是有序.重复的:dict的key不可以重复. ...