博客
关于我
Codeforces Round #716 (Div. 2) D. Cut and Stick
阅读量:686 次
发布时间:2019-03-17

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

显然:

对于一个区间我们只需要负责处理最多次出现的那个元素
(我们把剩下的元素称为其他元素)
而最优策略是拿两个最多元素和一个其他元素组合成一个序列

故某个区间的答案是

m a x ( 最 多 元 素 个 数 − 其 他 元 素 , 1 ) max(最多元素个数-其他元素,1) max(,1)

所以对于单个区间,我们只需要求出其中出现次数最多的元素个数。

这个是好做的。
因为每次加上一个数或者删去一个数,区间出现次数最多元素的元素个数只会增加或者减少一,所以我们只需要用一个 c n t [ i ] cnt[i] cnt[i]记录 i i i出现的次数, r n k [ i ] rnk[i] rnk[i]记录出现次数为 i i i次的元素个数。
每次维护 c n t [ i ] cnt[i] cnt[i] r n k [ i ] rnk[i] rnk[i]即可。(可以知道这个的复杂度是很低的,因为上文"出现次数最多元素的元素个数只会增加或者减少一")

同时因为询问是连续区间,所以想到莫队,复杂度可以控制在 O ( n n ) O(n\sqrt n) O(nn )以内。

#include
using namespace std; #define ll long long const int maxn=3e5+50; int n,q; int a[maxn],ans[maxn],rnk[maxn],cnt[maxn]; int nowl=1,nowr=0,nowans=0; struct qu { int l,r,num; }query[maxn]; bool cmp(qu a,qu b) { int t=sqrt(n); if(a.r/t!=b.r/t)return a.r/t
0)rnk[cnt[a[x]]]--; cnt[a[x]]++; rnk[cnt[a[x]]]++; nowans=max(nowans,cnt[a[x]]); } void del(int x) { rnk[cnt[a[x]]]--; cnt[a[x]]--; rnk[cnt[a[x]]]++; while(rnk[nowans]==0)nowans--; } int main() { scanf("%d%d",&n,&q); for(int i=1;i<=n;i++)scanf("%d",&a[i]); for(int i=1;i<=q;i++) { scanf("%d%d",&query[i].l,&query[i].r); query[i].num=i; } sort(query+1,query+1+q,cmp); for(int i=1;i<=q;i++) { while(nowr
query[i].l) { nowl--; add(nowl); } while(nowr>query[i].r) { del(nowr); nowr--; } while(nowl

但就本题而言我们的做法可以有很多种,其中有两种觉得非常有借鉴意义。

1、如果有一个数在区间内出现了超过 ( n + 1 ) / 2 (n+1)/2 (n+1)/2次,那么它一定在某个子区间内出现超过 ( n + 1 ) / 2 (n+1)/2 (n+1)/2次(否则矛盾),所以我们只需要用线段树处理出每个区间超过 ( n + 1 ) / 2 (n+1)/2 (n+1)/2次的数,然后分别 c h e c k check check即可。
2、如果有一个数在区间内出现了超过 ( n + 1 ) / 2 (n+1)/2 (n+1)/2次,那么我们随机一个位置,随机到这个数的概率大于 1 / 2 1/2 1/2,所以我们随机 n n n次, c h e c k check check每次取到的值,找到这个数的概率是非常大的。
注:check就简单二分下标~

同时顺便也学到了,对于出现次数大于 ( n + 1 ) / 2 (n+1)/2 (n+1)/2的众数我们有摩尔投票算法可以 O ( n ) O(n) O(n)求出…

b y   t h e   w a y by\,the\,way bytheway我们还可以复习一下中位数的一些冷知识,对于一个区间我们可以先二分一个数,然后统计大于这个数和小于这个数的数的个数,来 c h e c k check check,复杂度是 O ( n l o g n ) O(nlogn) O(nlogn)

转载地址:http://ihvhz.baihongyu.com/

你可能感兴趣的文章
mabatis 中出现&lt; 以及&gt; 代表什么意思?
查看>>
Mac book pro打开docker出现The data couldn’t be read because it is missing
查看>>
MAC M1大数据0-1成神篇-25 hadoop高可用搭建
查看>>
mac mysql 进程_Mac平台下启动MySQL到完全终止MySQL----终端八步走
查看>>
Mac OS 12.0.1 如何安装柯美287打印机驱动,刷卡打印
查看>>
MangoDB4.0版本的安装与配置
查看>>
Manjaro 24.1 “Xahea” 发布!具有 KDE Plasma 6.1.5、GNOME 46 和最新的内核增强功能
查看>>
mapping文件目录生成修改
查看>>
MapReduce程序依赖的jar包
查看>>
mariadb multi-source replication(mariadb多主复制)
查看>>
MariaDB的简单使用
查看>>
MaterialForm对tab页进行隐藏
查看>>
Member var and Static var.
查看>>
memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
查看>>
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>
Memcached:Node.js 高性能缓存解决方案
查看>>
memcache、redis原理对比
查看>>
memset初始化高维数组为-1/0
查看>>
Metasploit CGI网关接口渗透测试实战
查看>>
Metasploit Web服务器渗透测试实战
查看>>