博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ 3585: mex(分块+莫队)
阅读量:4973 次
发布时间:2019-06-12

本文共 1521 字,大约阅读时间需要 5 分钟。

解题思路

  首先直接莫队是能被卡的,时间复杂度不对。就考虑按照值域先进行分块再进行莫队,然后统计答案的时候就暴力扫所有的块,直到一个块内元素不满,再暴力扫这个块就行了,时间复杂度O(msqrt(n))

代码

#include
#include
#include
#include
#include
using namespace std;const int N=200005;const int SIZ=600; inline int rd(){ int x=0,f=1;char ch=getchar(); while(!isdigit(ch)) f=ch=='-'?0:1,ch=getchar(); while(isdigit(ch)) x=(x<<1)+(x<<3)+ch-'0',ch=getchar(); return f?x:-x;} int n,m,a[N],bl[N],siz,l[SIZ],r[SIZ],cnt[N],sum[SIZ],ans[N],num; struct Query{ int ql,qr,id; friend bool operator<(const Query A,const Query B){ if(A.ql/siz!=B.ql/siz) return A.ql
B.qr; return A.qr
n) return; cnt[a[x]]--;if(!cnt[a[x]]) sum[bl[a[x]]]--;}inline void add(int x){ if(a[x]>n) return ; if(!cnt[a[x]]) sum[bl[a[x]]]++;cnt[a[x]]++;}inline int query(){ if(!cnt[0]) return 0;int pos=-1; for(int i=1;i<=num;i++) if(sum[i]!=r[i]-l[i]+1) {pos=i;break;} if(pos==-1) return n+1; for(int i=l[pos];i<=r[pos];i++) if(!cnt[i]) return i;} int main(){ n=rd(),m=rd();siz=sqrt(n)+1;num=n/siz+(n%siz!=0); for(int i=1;i<=n;i++) a[i]=rd(),bl[i]=(i-1)/siz+1; for(int i=1;i<=num;i++) l[i]=(i-1)*siz+1,r[i]=i*siz;r[num]=n; for(int i=1;i<=m;i++) q[i].ql=rd(),q[i].qr=rd(),q[i].id=i; sort(q+1,q+1+m);int L=1,R=0; for(int i=1;i<=m;i++){ while(L
q[i].ql) {L--;add(L);} while(R
q[i].qr) {del(R);R--;} ans[q[i].id]=query(); } for(int i=1;i<=m;i++) printf("%d\n",ans[i]); return 0;}

转载于:https://www.cnblogs.com/sdfzsyq/p/10260828.html

你可能感兴趣的文章
样板操作数
查看>>
64位UBUNTU下安装adobe reader后无法启动
查看>>
组件:slot插槽
查看>>
Nginx配置文件nginx.conf中文详解(转)
查看>>
POJ 1308 Is It A Tree?(并查集)
查看>>
N进制到M进制的转换问题
查看>>
利用sed把一行的文本文件改成每句一行
查看>>
孤荷凌寒自学python第五十八天成功使用python来连接上远端MongoDb数据库
查看>>
求一个字符串中最长回文子串的长度(承接上一个题目)
查看>>
简单权限管理系统原理浅析
查看>>
springIOC第一个课堂案例的实现
查看>>
求输入成绩的平均分
查看>>
php PDO (转载)
查看>>
wordpress自动截取文章摘要代码
查看>>
[置顶] 一名优秀的程序设计师是如何管理知识的?
查看>>
scanf和gets
查看>>
highcharts 图表实例
查看>>
ubuntu下如何查看用户登录及系统授权相关信息
查看>>
秋季学期学习总结
查看>>
SpringBoot 优化内嵌的Tomcat
查看>>