大视野——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. Git学习——撤销修改

    git checkout -- <file> 当你修改完一个工作区的文件后,使用git status查看当前的状态.其中有说明,接下来你可以git add <file> 去添加 ...

  2. GIL 线程/进程池 同步异步

    GIL 什么是GIL 全局解释器锁,本质是一把互斥锁,是加在cpython解释器上的一把锁, 同一个进程内的所有线程需要先抢到GIL锁,才能执行python代码 为什么要有GIL cpython解释器 ...

  3. 落谷p3376 最大流EdmondsKarp增广路模板

    参考: https://blog.csdn.net/txl199106/article/details/64441994 分析: 该算法是用bfs求出是否有路从s到t, 然后建立反向边(关于反向边), ...

  4. WIN10配置MAVEN

    添加新的系统环境变量M2_HOME, 并设置其值为你安装的目录MAVEN_HOME=D:\Softwares\apache-maven-3.2.2. 更新系统PATH 变量, 添加;%M2_HOME% ...

  5. DOM、SAX、JDOM、DOM4J以及PULL在XML文件解析中的工作原理以及优缺点对比

    1. DOM(Document Object Model)文档对象模型1. DOM是W3C指定的一套规范标准,核心是按树形结构处理数据,DOM解析器读入XML文件并在内存中建立一个结构一模一样的&qu ...

  6. Experiments done

    喷重金属 换重金属溶液 荧光光合 备注 ASD 备注 高光谱 备注 泡EDTA 备注 电镜 备注 2018.12.19(day1) 2018.12.19(day1) 2018.12.18晚(day0) ...

  7. 在html页面中使用js变量

    Method 1:   <a id="xxxx">xxxxxxxxxxxxxxxxxx</a> <script type="text/jav ...

  8. VisionPro显示隐藏搜索区域

    假如我们需要显示两张图,一张显示CogPMAlignTool工具不带搜索区域的,一张显示CogPMAlignTool工具带搜索区域的图像 VisionPro显示隐藏搜索区域 VisionPro显示隐藏 ...

  9. Python第三方库之openpyxl(2)

    Python第三方库之openpyxl(2) 简单的使用 写一个工作簿 >>> from openpyxl import Workbook >>> from ope ...

  10. SQLserver查看某个视图的创建语句

    1.已经创建好的视图,查看视图创建时的源码 sp_helptext  '视图名' 如下: sp_helptext 'V_user' 方式2: sa账户登录SQLserver,选择视图---右键---- ...