[CF940F]Machine Learning
一句话题意
求区间数字出现次数的mex,带修改
sol
带修膜队不解释
带修膜队的排序!
struct query{
int id,l,r,t;
bool operator < (const query &b) const
{
if (l/block!=b.l/block) return l/block<b.l/block;
if (r/block!=b.r/block) return r/block<b.r/block;
return t<b.t;
}
}q1[N];
左端点所在块为第一关键字,右端点所在块为第二关键字,操作版本为第三关键字。
块的大小是\(n^{\frac{2}{3}}\),复杂度是\(O(n^{\frac{5}{3}})\)
然后就是离散化数组要开两倍
code
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
int gi()
{
int x=0,w=1;char ch=getchar();
while ((ch<'0'||ch>'9')&&ch!='-') ch=getchar();
if (ch=='-') w=0,ch=getchar();
while (ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();
return w?x:-x;
}
const int N = 2e5+5;
int n,m,block,gen,a[N],b[N],o[N],cnt1,cnt2,len,vis[N],cnt[N],num[N],t[N],ans[N];
struct query{
int id,l,r,t;
bool operator < (const query &b) const
{
if (l/block!=b.l/block) return l/block<b.l/block;
if (r/block!=b.r/block) return r/block<b.r/block;
return t<b.t;
}
}q1[N];
struct modify{int pos,val,pre;}q2[N];
void update(int x)
{
--num[cnt[a[x]]];
if (num[cnt[a[x]]]==0) --t[cnt[a[x]]/gen];
if (!vis[x]) ++cnt[a[x]];else --cnt[a[x]];
vis[x]^=1;
++num[cnt[a[x]]];
if (num[cnt[a[x]]]==1) ++t[cnt[a[x]]/gen];
}
void change(int x,int v)
{
if (!vis[x]) a[x]=v;
else update(x),a[x]=v,update(x);
}
int calc()
{
for (int i=0;;++i)
if (t[i]<gen)
for (int j=i*gen;;++j)
if (!num[j]) return j;
}
int main()
{
n=gi();m=gi();block=pow(n,0.666);gen=pow(n,0.5);
for (int i=1;i<=n;++i) a[i]=b[i]=o[++len]=gi();
for (int i=1;i<=m;++i)
{
int opt=gi(),l=gi(),r=gi();
if (opt==1) q1[++cnt1]=(query){cnt1,l,r,cnt2};
else q2[++cnt2]=(modify){l,r,b[l]},b[l]=o[++len]=r;
}
sort(o+1,o+len+1);len=unique(o+1,o+len+1)-o-1;
for (int i=1;i<=n;++i) a[i]=lower_bound(o+1,o+len+1,a[i])-o;
for (int i=1;i<=cnt2;++i)
{
q2[i].val=lower_bound(o+1,o+len+1,q2[i].val)-o;
q2[i].pre=lower_bound(o+1,o+len+1,q2[i].pre)-o;
}
sort(q1+1,q1+cnt1+1);
int L=1,R=0,X=1;num[0]=1e9;t[0]=1;//出现了0次的数字有无限多个
for (int i=1;i<=cnt1;++i)
{
while (X<q1[i].t) ++X,change(q2[X].pos,q2[X].val);
while (X>q1[i].t) change(q2[X].pos,q2[X].pre),--X;
while (L>q1[i].l) update(--L);
while (R<q1[i].r) update(++R);
while (L<q1[i].l) update(L++);
while (R>q1[i].r) update(R--);
ans[q1[i].id]=calc();
}
for (int i=1;i<=cnt1;++i) printf("%d\n",ans[i]);
return 0;
}
[CF940F]Machine Learning的更多相关文章
- CF940F Machine Learning 带修改莫队
题意:支持两种操作:$1.$ 查询 $[l,r]$ 每个数字出现次数的 $mex$,$2.$ 单点修改某一位置的值. 这里复习一下带修改莫队. 普通的莫队中,以左端点所在块编号为第一关键字,右端点大小 ...
- CF940F Machine Learning(带修莫队)
首先显然应该把数组离散化,然后发现是个带修莫队裸题,但是求mex比较讨厌,怎么办?其实可以这样求:记录每个数出现的次数,以及出现次数的出现次数.至于求mex,直接暴力扫最小的出现次数的出现次数为0的正 ...
- 【题解】CF940F Machine Learning
Link 题目大意:单点修改,每次询问一个区间的所有颜色出现次数的\(\text{Mex}.\) 例如,区间中三种颜色分别出现了\(2,2,3\)次,又因为其他颜色出现次数一定是\(0\),所以这里的 ...
- 【Machine Learning】KNN算法虹膜图片识别
K-近邻算法虹膜图片识别实战 作者:白宁超 2017年1月3日18:26:33 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本系列文章是作者结 ...
- 【Machine Learning】Python开发工具:Anaconda+Sublime
Python开发工具:Anaconda+Sublime 作者:白宁超 2016年12月23日21:24:51 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现 ...
- 【Machine Learning】机器学习及其基础概念简介
机器学习及其基础概念简介 作者:白宁超 2016年12月23日21:24:51 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本系列文章是作者结 ...
- 【Machine Learning】决策树案例:基于python的商品购买能力预测系统
决策树在商品购买能力预测案例中的算法实现 作者:白宁超 2016年12月24日22:05:42 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本 ...
- 【机器学习Machine Learning】资料大全
昨天总结了深度学习的资料,今天把机器学习的资料也总结一下(友情提示:有些网站需要"科学上网"^_^) 推荐几本好书: 1.Pattern Recognition and Machi ...
- [Machine Learning] Active Learning
1. 写在前面 在机器学习(Machine learning)领域,监督学习(Supervised learning).非监督学习(Unsupervised learning)以及半监督学习(Semi ...
随机推荐
- Nodejs的运行原理-模块篇
前言 使用Nodejs,就不可避免地引用第三方模块,它们有些是Nodejs自带的(例:http,net...),有些是发布在npm上的(例:mssql,elasticsearch...) 本篇章聚焦3 ...
- gitlab wiki 500
记录一次使用gitlab各种报500的问题,并怎么解决的描述下 一.问题背景 描述我第一次使用wiki的步骤: 二.问题描述 之后我进行任何合法的操作(创建页面使用全英文名称:页面不做任何修改,只是点 ...
- 购物车【JavaWeb小项目、简单版】
前言 为了巩固MVC的开发模式,下面就写一个购物车的小案例.. ①构建开发环境 导入需要用到的开发包 建立程序开发包 ②设计实体 书籍实体 public class Book { private St ...
- JDK1.7源码分析01-Collection
同步发布:http://www.yuanrengu.com/index.php/20180221.html Java的集合类主要由两个接口派生而出:Collection和Map.Collection是 ...
- [原创]ubuntu14.04部署ELK+redis日志分析系统
ubuntu14.04部署ELK+redis日志分析系统 [环境] host1:172.17.0.4 搭建ELK+redis服务 host2:172.17.0.3 搭建logstash+nginx服务 ...
- 二叉排序树、平衡二叉树、B树&B+树、红黑树的设计动机、缺陷与应用场景
之前面试时曾被问到"如果实现操作系统的线程调度应该采用什么数据结构?",因为我看过ucore的源码,知道ucore是采用斜堆的方式实现的,可以做到O(n)的插入.O(1)的查找.我 ...
- 对于任意大于1的自然数n,若n为奇数,则将n变为3n+1,否则变为n的一半。 经过若干次这样的变换,一定会使n变为1
对于任意大于1的自然数n,若n为奇数,则将n变为3n+1,否则变为n的一半.经过若干次这样的变换,一定会使n变为1.例如,3→10→5→16→8→4→2→1.输入n,输出变换的次数.n≤10 9 .样 ...
- Ubuntu上搭建SVN
参考文档:http://www.linuxidc.com/Linux/2016-08/133961.htm http://www.linuxidc.com/Linux/2015-01/111956.h ...
- UVa230 Borrowers
原题链接 UVa230 思路 这题输入时有一些字符串处理操作,可以利用string的substr()函数和find_last_of()函数更加方便,处理时不必更要把书名和作者对应下来,注意到原题书名的 ...
- 使用IntelliJ IDEA 和 Maven创建Java Web项目
1. Maven简介 相对于传统的项目,Maven 下管理和构建的项目真的非常好用和简单,所以这里也强调下,尽量使用此类工具进行项目构建, 它可以管理项目的整个生命周期. 可以通过其命令做所有相关的工 ...