【bzoj 4059】Non-boring sequences
这题的重点不在于代码,而在于复杂度分析……
首先我们肯定会写 $n^2$ 暴力,就是每次暴力扫 $[l,r]$ 区间,找到任意一个在此区间中只出现过一次的数。设其下标为 $mid$,显然在这个区间中任取一个子区间,只要这个子区间包含第 $mid$ 个数,这个子区间就是非“无聊的”,所以分治判断 $[l,mid-1]$ 和 $[mid+1,r]$ 两个区间是否不是“无聊的”即可。
接下来考虑优化。相信大家都听说过启发式合并,就是对于两个集合,如果合并这两个区集合的复杂度只与元素数较小的集合的元素数量有关,而与元素数较大的集合无关,设这两个集合的元素数量和为 $n$,那么我们就最多以 $O(n/2)$ 的时间合并这两个集合。
换成启发式合并的术语,就是:对于原序列的每一个位置,当包含这个数的区间往上合并时,只有区间大小至少 $\times 2$ 的情况下这个位置才会造成 $O(1)$ 的时间复杂度,否则这个位置不造成时间复杂度。所以每个位置最多造成 $O(\log{n})$ 的时间复杂度,共有 $n$ 个位置,总时间复杂度为 $O(n\times \log{n})$。
至于每个数是否在某个区间中只出现过一次……预处理一下每个位置的前驱后继即可(即上一个和下一个数值相同的位置),类似于建链表。
1 #include<bits/stdc++.h> 2 #define N 200010 3 using namespace std; 4 inline int read(){ 5 int x=0; bool f=1; char c=getchar(); 6 for(;!isdigit(c);c=getchar()) if(c=='-') f=0; 7 for(; isdigit(c);c=getchar()) x=(x<<3)+(x<<1)+(c^'0'); 8 if(f) return x; 9 return 0-x; 10 } 11 int T,n,a[N],pre[N],nxt[N]; 12 map<int,int> mp; 13 bool check(int l,int r){ 14 if(l>=r) return 1; 15 int i=l, j=r; 16 while(i<=j){ 17 if(pre[i]<l && nxt[i]>r) return check(l,i-1) && check(i+1,r); 18 if(i!=j && pre[j]<l && nxt[j]>r) return check(l,j-1) && check(j+1,r); 19 ++i, --j; 20 } 21 return 0; 22 } 23 int main(){ 24 T=read(); 25 while(T--){ 26 n=read(); 27 memset(nxt,0x7f,sizeof nxt); 28 mp.clear(); 29 map<int,int>::iterator it; 30 for(int i=0;i<n;++i){ 31 a[i]=read(); 32 it=mp.find(a[i]); 33 if(it!=mp.end()) 34 pre[i]=it->second, 35 nxt[it->second]=i; 36 else pre[i]=-1; 37 mp[a[i]]=i; 38 } 39 if(check(0,n-1)) printf("non-"); 40 printf("boring\n"); 41 } 42 return 0; 43 }
View Code
upd:建议用 $sort$ 排序建链表,我写个 $map$ 跑了倒数第一……
转载于:https://www.cnblogs.com/scx2015noip-as-php/p/bzoj4059.html
【bzoj 4059】Non-boring sequences相关推荐
- 【BZOJ - 4318】OSU!(概率dp,数学期望,期望的线性性)
题干: osu 是一款群众喜闻乐见的休闲软件. 我们可以把osu的规则简化与改编成以下的样子: 一共有n次操作,每次操作只有成功与失败之分,成功对应1,失败对应0,n次操作对应为1个长度为n的01串. ...
- 【BZOJ 2820】YY的GCD
[BZOJ 2820]YY的GCD Problem Description 给定\(N\), \(M\),求\(1\le x\le N\), \(1\le y\le M\) 且 \(gcd(x,y)\ ...
- 【BZOJ 2820】 YY的GCD
2820: YY的GCD Time Limit: 10 Sec Memory Limit: 512 MB Submit: 807 Solved: 404 [ Submit][ Status] ...
- 【BZOJ 2823】 [AHOI2012]信号塔
2823: [AHOI2012]信号塔 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 469 Solved: 198 [ Submit][ Sta ...
- 【BZOJ 3926】【ZJOI 2015】 诸神眷顾的幻想乡
[BZOJ 3926/ZJOI 2015] 诸神眷顾的幻想乡 [广义SA/广义SAM] 没想到陈立杰居然玩旧作- 题意: \;\;\;\;啊?~幻想乡?~一个树状太阳花田上每个点都有人穿着 c c种颜 ...
- 【bzoj 1833】【codevs 1359】 [ZJOI2010]count 数字计数(数位dp)
1833: [ZJOI2010]count 数字计数 Time Limit: 3 Sec Memory Limit: 64 MB Submit: 2774 Solved: 1230 [Submit ...
- 【最小树形图(奇怪的kruskal)】【SCOI 2012】【bzoj 2753】滑雪与时间胶囊
2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MB Submit: 1621 Solved: 570 Description ...
- 【BZOJ 1036】[ZJOI2008]树的统计Count
[题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1036 [题意] [题解] 树链剖分入门题; 每一条链维护一个线段树就好; uppest ...
- JZOJ 2256. 【BZOJ 2256】【ZJOI 2008】树的统计
Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w. 我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. ...
最新文章
- 连分数中一个有意思的小玩意儿
- 8个高效的Python爬虫框架分享
- 《剑指offer》整数中1出现的次数(从1到n整数中1出现的次数)
- 儿童手工制作日历_德莎胶带手工制作实用且美观的巨幅挂历,让你未雨绸缪
- explicitWidth与width,和用setActualSize()方法有什么区别?
- 对付镜像网站非常有效的办法
- MonoRail学习笔记十七:TransformFilter的使用
- 1.2 SQL注入原理-手工联合查询
- 在JavaScript面向对象编程中使用继承(4)
- php导入rtf文件获取内容,可以使用PHP在网页中显示RTF文件吗?
- 轻松搞明白:软切换和硬切换的区别
- SILENTCAST是另一类UBUNTU最好的GIF视频录制器
- 问题描述】原始题目:一只公鸡 5 文钱,一只母鸡 3 文钱,三只小鸡 1 文钱,用 100 文钱买 100 只鸡,请问公鸡,母鸡,小鸡各多少只?(推广)
- 将ppm格式转换为bmp格式的方式有哪些?
- Java获取本月第一天是本周第几天
- 汽车行业消费者洞察|车载屏幕是否越大越多就越好?
- 计算机打印机端口配置,如何设置打印机端口,打印机端口设置的方法步骤
- 签名来保证ASP.NET MVC OR WEBAPI的接口安全
- java中常用前后端交互框架,整合Spring-SpringMVC-MyBatis实现简单前后端交互
- 从0到1搭建电商营销数据分析平台(一)
热门文章
- ajax就收data的参数
- http://www.cnblogs.com/qtqq/p/5271164.html
- httpd-2.2和httpd-2.4虚拟主机的实现
- linux 内核调试方法
- 在linux下配置oracle的远程访问
- DPM 2010(三)---Exchange2010单邮箱恢复
- 陶哲轩实分析命题10.1.7
- 英国《金融时报》:全力加码早期投资,红杉中国在下一盘怎样的棋?
- Linu20180415三周第三次课(4月4日)
- 重建DC的DNS区域