【线段树】bzoj3585: mex
非常精妙的线段树题
Description
有一个长度为n的数组{a1,a2,...,an}。m次询问,每次询问一个区间内最小没有出现过的自然数。
Input
第一行n,m。
第二行为n个数。
从第三行开始,每行一个询问l,r。
Output
一行一个数,表示每个询问的答案。
Sample Input
2 1 0 2 1
3 3
2 3
2 4
1 2
3 5
Sample Output
2
3
0
3
HINT
数据规模和约定
对于100%的数据:
1<=n,m<=200000
0<=ai<=109
1<=l<=r<=n
对于30%的数据:
1<=n,m<=1000
题目分析
细节很精妙
#include<bits/stdc++.h>
const int maxn = ;
const int INF = 2e9; struct QRs
{
int l,r,id;
bool operator < (QRs a) const
{
return l < a.l||(l==a.l&&r < a.r);
}
}q[maxn];
int n,m,tt,now;
int a[maxn],b[maxn],mn[maxn<<];
int hsh[maxn],sgVal[maxn],ans[maxn];
int nxt[maxn],lst[maxn]; int read()
{
char ch = getchar();
int num = ;
bool fl = ;
for (; !isdigit(ch); ch = getchar())
if (ch=='-') fl = ;
for (; isdigit(ch); ch = getchar())
num = (num<<)+(num<<)+ch-;
if (fl) num = -num;
return num;
}
void pushdown(int x)
{
mn[x<<] = std::min(mn[x<<], mn[x]);
mn[x<<|] = std::min(mn[x<<|], mn[x]);
}
void build(int rt, int l, int r)
{
mn[rt] = INF;
if (l==r){
mn[rt] = sgVal[l];
return;
}
int mid = (l+r)>>;
build(rt<<, l, mid), build(rt<<|, mid+, r);
}
int query(int rt, int l, int r, int pos)
{
if (l==r) return mn[rt];
int mid = (l+r)>>;
pushdown(rt);
if (pos <= mid) return query(rt<<, l, mid, pos);
return query(rt<<|, mid+, r, pos);
}
void update(int rt, int L, int R, int l, int r, int c)
{
if (L <= l&&r <= R){
mn[rt] = std::min(mn[rt], c);
return;
}
int mid = (l+r)>>;
pushdown(rt);
if (L <= mid) update(rt<<, L, R, l, mid, c);
if (R > mid) update(rt<<|, L, R, mid+, r, c);
}
int main()
{
n = read(), m = read(), tt = ;
for (int i=; i<=n; i++)
{
a[i] = read();
if (a[i] > n) a[i] = n+;
}
for (int i=; i<=m; i++)
q[i].l = read(), q[i].r = read(), q[i].id = i;
std::sort(q+, q+m+);
for (int i=; i<=n; i++)
{
hsh[a[i]] = ;
if (a[i]==tt)
while (hsh[tt]) tt++;
sgVal[i] = tt;
}
for (int i=n; i>=; i--)
{
tt = a[i];
nxt[i] = lst[tt], lst[tt] = i;
}
build(, , n);
now = ;
for (int i=; i<=m; i++)
{
for (; now < q[i].l; now++)
{
if (!nxt[now]) nxt[now] = n+;
update(, now, nxt[now]-, , n, a[now]);
}
ans[q[i].id] = query(, , n, q[i].r);
}
for (int i=; i<=m; i++)
printf("%d\n",ans[i]);
return ;
}
END
【线段树】bzoj3585: mex的更多相关文章
- 【bzoj3585】mex 线段树 mex,sg
Description 有一个长度为n的数组{a1,a2,…,an}.m次询问,每次询问一个区间内最小没有出现过的自然数. Input 第一行n,m. 第二行为n个数. 从第三行开始,每行一个询问l, ...
- [bzoj3339]Rmq Problem||[bzoj3585]mex_线段树
Rmq Problem bzoj-3339||mex bzoj-3585 题目大意:给定一个长度为n的数列a,多次讯问区间l,r中最小的不属于集合{$A_l,A_{l+1}...A_r$}的非负整数. ...
- HDU-4747 Mex(线段树区间更新)
题目大意:给一个长度为n的整数序列,定义mex(i,j)表示区间[i,j]中没有出现过的最小非负整数,求sigma(mex(i,j)),即序列中所有连续非空子区间的mex之和. 题目分析: answe ...
- HDU-4747 Mex 线段树
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4747 题意:求一个数列中,所有mex(L,R)的和. 注意到mex是单调不降的,那么首先预处理出mex ...
- [置顶] hdu4747 Mex 线段树
题意:给你一个序列,让你求出对于所有区间<i, j>的mex和,mex表示该区间没有出现过的最小的整数. 思路:从时限和点数就可以看出是线段树,并且我们可以枚举左端点i, 然后求出所有左端 ...
- [Codeforces]817F. MEX Queries 离散化+线段树维护
[Codeforces]817F. MEX Queries You are given a set of integer numbers, initially it is empty. You sho ...
- 主席树||可持久化线段树+离散化 || 莫队+分块 ||BZOJ 3585: mex || Luogu P4137 Rmq Problem / mex
题面:Rmq Problem / mex 题解: 先离散化,然后插一堆空白,大体就是如果(对于以a.data<b.data排序后的A)A[i-1].data+1!=A[i].data,则插一个空 ...
- BZOJ.3585.mex(线段树)
题目链接 题意:多次求区间\(mex\). 考虑\([1,i]\)的\(mex[i]\),显然是单调的 而对于\([l,r]\)与\([l+1,r]\),如果\(nxt[a[l]]>r\),那么 ...
- HDU 4747 Mex (2013杭州网络赛1010题,线段树)
Mex Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Total Submis ...
随机推荐
- 稳定UI运行结果-自动化测试失败重试和截图
运行自动化测试的时候,有时会因为网络不稳定,测试环境或者第三方环境正在重启而造成用例运行结果不稳定,时而能跑过时而跑不过.这些难以重现的环境因素造成的用例失败会让测试人员很困扰,排查即耗费时间也没有太 ...
- adb server version (39) doesn't match this client (40); killing...
在启动RN项目的时候也报错,上面的错误是在adb的环境变量中的位置和android studio的sdk不是一个位置.adb是在sdk中的,所以他们应该是一致的位置 android studio的sd ...
- hdu 6319 Problem A. Ascending Rating (2018 Multi-University Training Contest 3)
#include <stdio.h> #include <iostream> #include <cstdlib> #include <cmath> # ...
- JQuery | trigger() 方法
trigger() 方法触发被选元素的指定事件类型. 语法格式: trigger(type,[data]) type:触发事件类型 [data]:可选项,表示在触发事件时传递给函数的附加参数. 实例: ...
- Glide加载图片的事例
//获取图片的url String url = resultsEntity.getUrl(); //判断获取的图片是否存在 if (resultsEntity.getItemHeight() > ...
- HDU4405 Aeroplane chess(期望dp)
题意 抄袭自https://www.cnblogs.com/Paul-Guderian/p/7624039.html 正在玩飞行棋.输入n,m表示飞行棋有n个格子,有m个飞行点,然后输入m对u,v表示 ...
- Git .gitignore 设置为全局global
在操作Git时,我们会将修改的内容$git add . 到Git,Git会提示我们哪些文件都修改了.此时提示中会包括系统自动修改的文件,bin文件等.而我们add到Git时,并不希望将这些文件也一同a ...
- [Python]输出中文报错的解决方法
问题现象:在PyCharm工具编辑python语句输出中文时,程序报错. 解决方法(2种): 1.在代码开头加#coding=utf-8(注意要加#) 2.还是在代码开头加#-*- coding: u ...
- 【Web应用-FTP】FTP 容量显示说明
现象描述 Azure 门户显示的文件系统存储容量跟网站本身的磁盘空间不符. 问题分析 Azure Web 应用的文件系统存储用量和网站本身有关,具体容量如下所示: 但目前门户预览中关于 FTP 的容量 ...
- nmon各配置项含义介绍
1)nmon各配置项含义介绍