题目链接  Codeforces Round #466 (Div. 2) Problem F

题意  给定一列数和若干个询问,每一次询问要求集合$\left\{c_{0}, c_{1}, c_{2}, c_{3}, ...,c_{10^{9}}\right\}$的$mex$

    同时伴有单点修改的操作。

根据题目询问的这个集合的性质可以知道答案不会超过$\sqrt{n}$,那么每次询问的时候直接暴力找就可以了。

剩下的都是可修改莫队的基本操作。

#include <bits/stdc++.h>

using namespace std;

#define rep(i, a, b)	for (int i(a); i <= (b); ++i)
#define dec(i, a, b) for (int i(a); i >= (b); --i) const int N = 1e5 + 10; int c[N], f[N << 1], vis[N], ans[N];
int a[N], b[N], d[N << 1];
int n, m, bs, et;
int cnt = 0, tot = 0;
int op, x, y;
int l, r;
int net, ret; struct node{
int l, r, lb, rb, id, x;
friend bool operator < (const node &a, const node &b){
if (a.lb != b.lb) return a.lb < b.lb;
if (a.rb != b.rb) return a.rb < b.rb;
return a.x < b.x;
}
} q[N]; struct upd{
int pos, x, y;
} e[N]; void update(int x){
if (vis[x]){
--c[f[a[x]]];
--f[a[x]];
++c[f[a[x]]];
} else{
--c[f[a[x]]];
++f[a[x]];
++c[f[a[x]]];
} vis[x] ^= 1;
} void change(int pos, int x){
if (vis[pos]){
update(pos);
a[pos] = x;
update(pos);
} else a[pos] = x;
} int main(){ scanf("%d%d", &n, &m);
bs = pow(n, 2. / 3.);
bs = max(bs, 1);
rep(i, 1, n) scanf("%d", a + i), d[++et] = a[i]; rep(i, 1, m){
scanf("%d%d%d", &op, &x, &y);
if (op == 1){
++cnt;
q[cnt].l = x;
q[cnt].r = y;
q[cnt].lb = (x - 1) / bs + 1;
q[cnt].rb = (y - 1) / bs + 1;
q[cnt].id = cnt;
q[cnt].x = tot;
} else{
++tot;
e[tot].pos = x;
e[tot].y = y;
d[++et] = y;
}
} sort(d + 1, d + et + 1);
net = unique(d + 1, d + et + 1) - d - 1;
rep(i, 1, n) a[i] = lower_bound(d + 1, d + net + 1, a[i]) - d;
rep(i, 1, tot) e[i].y = lower_bound(d + 1, d + net + 1, e[i].y) - d; rep(i, 1, n) b[i] = a[i]; rep(i, 1, tot){
e[i].x = b[e[i].pos];
b[e[i].pos] = e[i].y;
} sort(q + 1, q + cnt + 1); l = 1, r = 0, x = 0; rep(i, 1, cnt){
while (x < q[i].x){
++x;
change(e[x].pos, e[x].y);
} while (x > q[i].x){
change(e[x].pos, e[x].x);
--x;
} while (r < q[i].r) update(++r);
while (r > q[i].r) update(r--);
while (l > q[i].l) update(--l);
while (l < q[i].l) update(l++); rep(j, 1, 1e5) if (!c[j]){ ret = j; break;} ans[q[i].id] = ret;
} rep(i, 1, cnt) printf("%d\n", ans[i]);
return 0;
}

  

Codeforces 940F Machine Learning (带修改莫队)的更多相关文章

  1. Codeforces 940F Machine Learning 带修改莫队

    题目链接 题意 给定一个长度为\(n\)的数组\(a\),\(q\)个操作,操作分两种: 对于区间\([l,r]\),询问\(Mex\{c_0,c_1,c_2,⋯,c_{10^9}\}\),其中\(c ...

  2. CF940F Machine Learning 带修改莫队

    题意:支持两种操作:$1.$ 查询 $[l,r]$ 每个数字出现次数的 $mex$,$2.$ 单点修改某一位置的值. 这里复习一下带修改莫队. 普通的莫队中,以左端点所在块编号为第一关键字,右端点大小 ...

  3. BZOJ2120 数颜色(带修改莫队)

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...

  4. bzoj 2120 数颜色 带修改莫队

    带修改莫队,每次查询前调整修改 #include<cstdio> #include<iostream> #include<cstring> #include< ...

  5. BZOJ2120&2453数颜色——线段树套平衡树(treap)+set/带修改莫队

    题目描述 墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会像你发布如下指令: 1. Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色的画笔. 2 ...

  6. BZOJ.2453.维护队列([模板]带修改莫队)

    题目链接 带修改莫队: 普通莫队的扩展,依旧从[l,r,t]怎么转移到[l+1,r,t],[l,r+1,t],[l,r,t+1]去考虑 对于当前所在的区间维护一个vis[l~r]=1,在修改值时根据是 ...

  7. [BZOJ4129]Haruna’s Breakfast(树上带修改莫队)

    BZOJ3585,BZOJ2120,BZOJ3757三合一. 对于树上路径问题,树链剖分难以处理的时候,就用树上带修改莫队. 这里的MEX问题,使用BZOJ3585的分块方法,平衡了时间复杂度. 剩下 ...

  8. BZOJ.3052.[WC2013]糖果公园(树上莫队 带修改莫队)

    题目链接 BZOJ 当然哪都能交(都比在BZOJ交好),比如UOJ #58 //67376kb 27280ms //树上莫队+带修改莫队 模板题 #include <cmath> #inc ...

  9. BZOJ2120数颜色(带修改莫队)

    莫队算法是一种数据结构的根号复杂度替代品,主要应用在询问[l,r]到询问[l+1,r]和[l,r+1]这两个插入和删除操作复杂度都较低的情况下.具体思想是:如果把一个询问[l,r]看做平面上的点(l, ...

  10. 【BZOJ】4129: Haruna’s Breakfast 树分块+带修改莫队算法

    [题意]给定n个节点的树,每个节点有一个数字ai,m次操作:修改一个节点的数字,或询问一条树链的数字集合的mex值.n,m<=5*10^4,0<=ai<=10^9. [算法]树分块+ ...

随机推荐

  1. 剑指Offer - 九度1512 - 用两个栈实现队列

    剑指Offer - 九度1512 - 用两个栈实现队列2013-11-29 21:23 题目描述: 用两个栈来实现一个队列,完成队列的Push和Pop操作.队列中的元素为int类型. 输入: 每个输入 ...

  2. js学习日记-各种宽高总结(配图)

    1.窗口和浏览器 window.innerWidth.window.innerHeight   浏览器内部可用宽高 window.outerWidth.window.outerHeight   浏览器 ...

  3. 给vmstat加上时间戳

    vmstat -n 5 | awk '{print strftime("[%Y-%m-%d %H:%M:%S]"),$0}' 或者 vmstat -n 5 | awk '{ pri ...

  4. Oracle 学习----游标(使用带参光标cursor)

    --表参照无参光标页信息 --注意:红色就是参数 declare cursor tt(pkeycode temp.keycode%type) is select name,sal from temp ...

  5. virsh command

    http://www.cnblogs.com/chenjiahe/category/845519.html resize qemu-img resize win2k8r2.qcow2 40G conv ...

  6. maven中mapper.xml不发布的问题

    在自定义的包中定义了mapper.xml然后利用mybatis的扫描包形式来动态创建mapper 开启工程报错: 说无效的绑定 原因: 发布的war中,工程包中的mapper根本就没有出现在class ...

  7. 【操作系统】关于C语言设计程序退出自动关闭窗口的问题

    有些同学在做实验一 命令解释程序的编写的时候,输入quit命令退出程序,窗口并没有关闭,如下图所示需要Press any key to continue(按任意键)之后才关闭. 出现这个结果的原因是在 ...

  8. ubuntu16.04 使用问题笔记

    1.问题: 下列软件包有未满足的依赖关系: vim : 依赖: vim-common (= 2:7.4.826-1ubuntu1) 但是 2:7.4.1689-3ubuntu1 正要被安装 E: 无法 ...

  9. MVC4.0 bug 神奇的是事情 bool 值变成了 onclick ,非常奇怪的

    foreach (var item in ViewBag.PhotoGroupList) { // 这里很奇怪 item.IS_DISPLAY  是布尔值 如果直接写 @item.IS_DISPLAY ...

  10. 【POJ 2752 Seek the Name, Seek the Fame】

    Time Limit: 2000MSMemory Limit: 65536K Description The little cat is so famous, that many couples tr ...