「CF643G」 Choosing Ads

传送门

如果你知道摩尔投票法可以扩展事实上是个一眼题,又好写又好调。

首先摩尔投票法是用来求众数定义为超过所有数个数一半的数的一个算法。

大致算法流程:

  • 将第一个数其设为我们预选的众数,并给其一个权值 \(w=1\)
  • 接下来,每当我们遍历一个数,若其与预选的众数相同,便使其权值加一,否则使其减一。
  • 若预选的众数权值变为 \(0\),则将使其变为 \(0\) 的这个数设为预选的众数。

最后留下的数就是答案。

然后这东西显然可以通过线段树进行合并。

然后这个东西你发现,如果我们不止预选一个数,而是预选 \(k\) 个数,我们就可以求出出现概率超过 \(\frac {1}{k+1}\) 的众数。

然后这个题就没了。

/*---Author:HenryHuang---*/
/*---Never Settle---*/
#include<bits/stdc++.h>
using namespace std;
const int maxn=1.5e5+5;
vector<pair<int,int> > tree[maxn<<2];
int tag[maxn<<2];
int n,m,p;
int a[maxn];
vector<pair<int,int> > merge(vector<pair<int,int> > a,vector<pair<int,int> > b){
for(auto [x,y]:b){
int flag=0;
for(auto &[xx,yy]:a){
if(xx==x){
yy+=y,flag=1;
break;
}
}
if(flag) continue;
a.emplace_back(x,y);
if((int)a.size()<=p) continue;
int mn=n;
for(auto [xx,yy]:a) mn=min(mn,yy);
vector<pair<int,int> > tmp;
for(auto [xx,yy]:a)
if(yy-mn) tmp.emplace_back(xx,yy-mn);
a=tmp;
}
return a;
}
void reset(int t,int len,int num){
tree[t].clear();
tree[t].emplace_back(num,len);
}
void down(int t,int ls,int rs){
if(tag[t]){
tag[t<<1]=tag[t],tag[t<<1|1]=tag[t];
reset(t<<1,ls,tag[t]),reset(t<<1|1,rs,tag[t]);
tag[t]=0;
}
}
void build(int l,int r,int t){
if(l==r){
tree[t].emplace_back(a[l],1);
return ;
}
int mid=(l+r)>>1;
build(l,mid,t<<1);
build(mid+1,r,t<<1|1);
tree[t]=merge(tree[t<<1],tree[t<<1|1]);
}
void modify(int ll,int rr,int l,int r,int num,int t){
if(ll<=l&&r<=rr){
reset(t,r-l+1,num),tag[t]=num;
return ;
}
int mid=(l+r)>>1;
down(t,mid-l+1,r-mid);
if(ll<=mid) modify(ll,rr,l,mid,num,t<<1);
if(rr>mid) modify(ll,rr,mid+1,r,num,t<<1|1);
tree[t]=merge(tree[t<<1],tree[t<<1|1]);
}
vector<pair<int,int> > query(int ll,int rr,int l,int r,int t){
if(ll<=l&&r<=rr) return tree[t];
int mid=(l+r)>>1;
down(t,mid-l+1,r-mid);
vector<pair<int,int> > tmp;
if(ll<=mid) tmp=merge(tmp,query(ll,rr,l,mid,t<<1));
if(rr>mid) tmp=merge(tmp,query(ll,rr,mid+1,r,t<<1|1));
return tmp;
}
int main(){
ios::sync_with_stdio(0);
cin.tie(0),cout.tie(0);
cin>>n>>m>>p;p=100/p;
for(int i=1;i<=n;++i) cin>>a[i];
build(1,n,1);
for(int i=1;i<=m;++i){
int opt,l,r,v;cin>>opt>>l>>r;
if(opt==1){
cin>>v;
modify(l,r,1,n,v,1);
}
else{
auto ans=query(l,r,1,n,1);
cout<<ans.size()<<' ';
for(auto [x,y]:ans) cout<<x<<' ';
cout<<'\n';
}
}
return 0;
}

「CF643G」 Choosing Ads的更多相关文章

  1. 「AGC025D」 Choosing Points

    「AGC025D」 Choosing Points 神仙构造题. 首先你会尝试暴力做,先随便选一个点,然后把当前能选得全选上,然后你发现这样样例都过不了. 然后我们可以这样考虑:你把距离为 \(\sq ...

  2. 题解-CF643G Choosing Ads

    CF643G Choosing Ads \(n\) 和 \(m\) 和 \(p\) 和序列 \(a_i(1\le i\le n)\).\(m\) 种如下操作: 1 l r id 令 \(i\in[l, ...

  3. 「译」JUnit 5 系列:条件测试

    原文地址:http://blog.codefx.org/libraries/junit-5-conditions/ 原文日期:08, May, 2016 译文首发:Linesh 的博客:「译」JUni ...

  4. 「译」JUnit 5 系列:扩展模型(Extension Model)

    原文地址:http://blog.codefx.org/design/architecture/junit-5-extension-model/ 原文日期:11, Apr, 2016 译文首发:Lin ...

  5. JavaScript OOP 之「创建对象」

    工厂模式 工厂模式是软件工程领域一种广为人知的设计模式,这种模式抽象了创建具体对象的过程.工厂模式虽然解决了创建多个相似对象的问题,但却没有解决对象识别的问题. function createPers ...

  6. 「C++」理解智能指针

    维基百科上面对于「智能指针」是这样描述的: 智能指针(英语:Smart pointer)是一种抽象的数据类型.在程序设计中,它通常是经由类型模板(class template)来实做,借由模板(tem ...

  7. 「JavaScript」四种跨域方式详解

    超详细并且带 Demo 的 JavaScript 跨域指南来了! 本文基于你了解 JavaScript 的同源策略,并且了解使用跨域跨域的理由. 1. JSONP 首先要介绍的跨域方法必然是 JSON ...

  8. 「2014-5-31」Z-Stack - Modification of Zigbee Device Object for better network access management

    写一份赏心悦目的工程文档,是很困难的事情.若想写得完善,不仅得用对工具(use the right tools),注重文笔,还得投入大把时间,真心是一件难度颇高的事情.但,若是真写好了,也是善莫大焉: ...

  9. 「2014-3-18」multi-pattern string match using aho-corasick

    我是擅(倾)长(向)把一篇文章写成杂文的.毕竟,写博客记录生活点滴,比不得发 paper,要求字斟句酌八股结构到位:风格偏杂文一点,也是没人拒稿的.这么说来,arxiv 就好比是 paper 世界的博 ...

随机推荐

  1. Jmeter- 笔记12 - 性能测试分析 & 性能测试流程

    性能测试分析 场景设计.监视图表: 设计场景:阶梯式.波浪式 监视器: 收集用于性能分析的数据:TPS图表.聚合报告\汇总报告.察看结果树.响应时间.吞吐量 服务器资源监控:cpu.内存.磁盘io 分 ...

  2. javascript数组排序算法之选择排序

    前言 作为一名程序员数组的排序算法是必须要掌握的,今天来图解----选择排序 选择排序原理 首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大) ...

  3. 解决maven依赖冲突问题

    解决maven依赖冲突问题 1.idea 安装maven helper插件 2.打开pom.xml文件 底部多出一个Dependency Analyzer选项 点开这个选项 找到冲突,点击右键,选择E ...

  4. Proteus中包含的传感器类型(Transducers)

    1. 传感器列表 2. 部分传感器的测量电路 (1)光照传感器,搭采样电阻,测电压输出. (2)距离传感器,带采样电阻,测电压输出. (3)粉尘传感器,测PWM脉宽 其余传感器多为总线类型的传感器,各 ...

  5. TensorFlow常用Python扩展包

    TensorFlow常用Python扩展包 TensorFlow 能够实现大部分神经网络的功能.但是,这还是不够的.对于预处理任务.序列化甚至绘图任务,还需要更多的 Python 包. 下面列出了一些 ...

  6. SQL进阶总结(一)

    学而不思则罔,趁着假期好好总结下SQL的编程知识. 掌握SQL,首先有两个知识点要明确,要贯穿在我们整个学习SQL的过程中. SQL 不同于之前学习的面向过程.面向编程语言,SQL是一门面向集合的编程 ...

  7. 【NX二次开发】导出x_t、导入x_t例子,UF_PS_export_data、UF_PS_import_data

    获取blockUI 体收集器选择的体,导出x_t: std::vector<TaggedObject*>objects = bodySelect0->GetSelectedObjec ...

  8. 如何在CentOS 7上搭建LAMP环境(使用YUM或编译)

    什么是LAMP? LAMP是Linux,Apache,MySQL和PHP的缩写. 它是一堆应用程序的堆栈,它们在Web服务器上一起工作以托管网站. 话虽如此,每个程序都有不同的目的: 在LAMP中, ...

  9. opencv——import导包出现错误

    原因:编辑器找不到,CV2的模块,也就是导入这个模块失败: 原因可能是sublime找不到这个这个模块的位置,不知道这个包在哪里,这时候需要我们安装OpenCV的一个扩展包. 解决步骤: ①:找到py ...

  10. Huawei USG6530防火墙

    CF卡:(Compact Flash)最初是一种用于便携式电子设备的数据存储设备.作为一种存储设备,它革命性的使用了闪存 与sd卡的区别:SD卡的优点是安全.体积小巧,价格较之CF卡相对比较低,适合用 ...