BZOJ4059[Cerc2012]Non-boring sequences(扫描线/分治)
这题正解应该是扫描线,就是发现DP的区间在两个维度都为连续段,于是可以直接扫描线。但不幸的是,扫描线常数过大,无法通过本题。
考虑分治。对于分治区间[l,r],可以记录pre和nxt表示其前/后一次出现的位置,每当遇到一个出现次数=1的数,可以直接把区间分为两半判断,反之则丢掉这个数,而仅会分治一次,且掐断地方是先判两边,复杂度近似O(nlogn)。
实在太坑了,其实是一道练习扫描线的好题qwq
- #include<cstdio>
- #include<algorithm>
- #define lson l,mid,rt<<1
- #define rson mid+1,r,rt<<1|1
- using namespace std;
- const int N=2e5+;
- typedef long long ll;
- struct line{int x,l,r,v;}c[N<<];
- int n,m,a[N],b[N],L[N],R[N],pre[N],sum[N<<],cnt[N<<];
- bool cmp(line a,line b){return a.x<b.x;}
- void insert(int a1,int a2,int b1,int b2)
- {c[++m]=(line){a1,b1,b2,},c[++m]=(line){a2+,b1,b2,-};}
- void build(int l,int r,int rt)
- {
- sum[rt]=cnt[rt]=;
- if(l==r)return;
- int mid=l+r>>;
- build(lson),build(rson);
- }
- void pushup(int l,int r,int rt)
- {
- if(cnt[rt])sum[rt]=r-l+;
- else if(l==r)sum[rt]=;
- else sum[rt]=sum[rt<<]+sum[rt<<|];
- }
- void update(int L,int R,int v,int l,int r,int rt)
- {
- if(L<=l&&r<=R){cnt[rt]+=v,pushup(l,r,rt);return;}
- int mid=l+r>>;
- if(L<=mid)update(L,R,v,lson);
- if(R>mid)update(L,R,v,rson);
- pushup(l,r,rt);
- }
- int main()
- {
- int T;scanf("%d",&T);
- while(T--)
- {
- scanf("%d",&n);
- build(,n,);
- for(int i=;i<=n;i++)scanf("%d",&a[i]),b[i]=a[i];
- sort(b+,b+n+);
- m=unique(b+,b+n+)-b-;
- for(int i=;i<=n;i++)a[i]=lower_bound(b+,b+m+,a[i])-b;
- m=;
- for(int i=;i<=n;i++)pre[i]=;
- for(int i=;i<=n;i++)L[i]=pre[a[i]],pre[a[i]]=i;
- for(int i=;i<=n;i++)pre[i]=n+;
- for(int i=n;i;i--)R[i]=pre[a[i]],pre[a[i]]=i;
- for(int i=;i<=n;i++)insert(L[i]+,i,i,R[i]-);
- sort(c+,c+m+,cmp);
- ll ans=;
- for(int i=,p=;i<=n;i++)
- {
- while(p<m&&c[p+].x==i)p++,update(c[p].l,c[p].r,c[p].v,,n,);
- ans+=sum[];
- }
- if(ans==1ll*n*(n+)/)puts("non-boring");
- else puts("boring");
- }
- }
扫描线的TLE代码
- #include<cstdio>
- #include<algorithm>
- #include<map>
- using namespace std;
- const int N=2e5+;
- int n,m,a[N],pre[N],nxt[N];
- map<int,int>lst;
- bool solve(int l,int r)
- {
- if(l>=r)return ;
- int p=l,q=r;
- while(p<=q)
- {
- if(pre[p]<l&&nxt[p]>r)return solve(l,p-)&&solve(p+,r);p++;
- if(pre[q]<l&&nxt[q]>r)return solve(l,q-)&&solve(q+,r);q--;
- }
- return ;
- }
- int main()
- {
- int T;scanf("%d",&T);
- while(T--)
- {
- lst.clear();
- scanf("%d",&n);
- for(int i=,pos;i<=n;i++)scanf("%d",&a[i]),pos=lst[a[i]],nxt[pos]=i,pre[i]=pos,lst[a[i]]=i;
- for(int i=;i<=n;i++)nxt[lst[a[i]]]=n+;
- if(solve(,n))puts("non-boring");else puts("boring");
- }
- }
分治的AC代码
BZOJ4059[Cerc2012]Non-boring sequences(扫描线/分治)的更多相关文章
- bzoj4059 [Cerc2012]Non-boring sequences && bzoj5200 [NWERC2017]Factor-Free Tree
https://konnyakuxzy.github.io/BZPRO/JudgeOnline/4059.html https://cn.vjudge.net/problem/Gym-100624D ...
- 【启发式拆分】bzoj4059: [Cerc2012]Non-boring sequences
这个做法名字是从武爷爷那里看到的…… Description 我们害怕把这道题题面搞得太无聊了,所以我们决定让这题超短.一个序列被称为是不无聊的,仅当它的每个连续子序列存在一个独一无二的数字,即每个子 ...
- bzoj4059 [Cerc2012]Non-boring sequences
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4059 [题解] 考虑分治.定义过程solve(l,r)为判断全在[l,r]范围内的所有连续子 ...
- BZOJ 4059: [Cerc2012]Non-boring sequences(启发式分治)
传送门 解题思路 首先可以想到要预处理一个\(nxt_i\)和\(pre_i\),表示前后与当前位置权值相同的节点,那么这样可以迅速算出某个点在某段区间是否出现多次.然后这样的话就考虑分治,对于\([ ...
- UVA1608-Non-boring sequences(分治)
Problem UVA1608-Non-boring sequences Accept: 227 Submit: 2541Time Limit: 3000 mSec Problem Descript ...
- Non-boring sequences(启发式分治)
题意:一个序列被称作是不无聊的,当且仅当,任意一个连续子区间,存在一个数字只出现了一次,问给定序列是否是不无聊的. 思路:每次找到一个只出现了一次的点,其位置的pos,那么继续分治[L,pos-1], ...
- UVA - 1608 Non-boring sequences (分治)
题意:如果一个序列的任意连续子序列中至少有一个只出现一次的元素,则称这个序列式为non-boring.输入一个n(n≤200000)个元素的序列A(各个元素均为109以内的非负整数),判断它是否无聊. ...
- HDU 5324 Boring Class CDQ分治
题目传送门 题目要求一个3维偏序点的最长子序列,并且字典序最小. 题解: 这种题目出现的次数特别多了.如果不需要保证字典序的话直接cdq就好了. 这里需要维护字典序的话,我们从后往前配对就好了,因为越 ...
- 【刷题】BZOJ 4059 [Cerc2012]Non-boring sequences
Description 我们害怕把这道题题面搞得太无聊了,所以我们决定让这题超短.一个序列被称为是不无聊的,仅当它的每个连续子序列存在一个独一无二的数字,即每个子序列里至少存在一个数字只出现一次.给定 ...
随机推荐
- C# 使用复选框实现循环添加多条信息入库!
先在前台获取到所有要添加信息的Id $('.imgid').each(function () { if ($(this).attr("src" ...
- 关于博主 5ab
博主是 5ab,一个 ZJ 初一大蒟蒻. 以 5ab 及类似名号在各大 OJ 出没. 欢迎来到 5ab 这个超级大蒟蒻的博客!!! My luogu blog 关于 5ab 的码风 大括号换行!!! ...
- text字体样式(多行结尾省略,彩色渐变字体)
text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; ...
- ntp时间同步服务器
[root@localhost ~]# ntpdate time.nist.gov 虚拟机时间不对 自动同步 sudo ntpdate asia.pool.ntp.org 要是同步后时间还是不 ...
- Mybatis(1)-初识mybaits
一.概述 1.概述 mybatis 是一个优秀的基于 java 的持久层框架,它内部封装了 jdbc,使开发者只需要关注 sql 语句本身, 而不需要花费精力去处理加载驱动.创建连接.创建 state ...
- vmware桥接模式-无法内网通-克隆机要删除的文件-ssl
网卡太多自动模式有时候无法正常通信需要绑定外部网卡 rm /etc/udev/rules.d/-persistent-ipoib.rules vmware报错 Microsoft Runtime DL ...
- C#构造函数调用其他构造函数
http://blog.csdn.net/dogfish/article/details/6990266 <-- 虏来的地 public class Class1 { public Class ...
- Spring Boot作为Spring Cloud基础设施
spring cloud包含的核心特性: Distributed/versioned configuration(分布式配置) Service registration and discovery(服 ...
- Ubuntu下caffe:用自己的图片训练并测试AlexNet模型
参考博客:https://blog.csdn.net/eereere/article/details/79118645#commentBox 目录 1.准备图片 2. 将 图片路径写入txt 参考 这 ...
- Git--git log
参考 https://www.cnblogs.com/bellkosmos/p/5923439.html https://www.cnblogs.com/mkl34367803/p/9219913.h ...