题目链接:https://vjudge.net/problem/HYSBZ-2120

2120: 数颜色

Time Limit: 6 Sec  Memory Limit: 259 MB
Submit: 6898  Solved: 2781
[Submit][Status][Discuss]

Description

墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问。墨墨会像你发布如下指令: 1、 Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色的画笔。 2、 R P Col 把第P支画笔替换为颜色Col。为了满足墨墨的要求,你知道你需要干什么了吗?

Input

第1行两个整数N,M,分别代表初始画笔的数量以及墨墨会做的事情的个数。第2行N个整数,分别代表初始画笔排中第i支画笔的颜色。第3行到第2+M行,每行分别代表墨墨会做的一件事情,格式见题干部分。

Output

对于每一个Query的询问,你需要在对应的行中给出一个数字,代表第L支画笔到第R支画笔中共有几种不同颜色的画笔。

Sample Input

6 5
1 2 3 4 5 5
Q 1 4
Q 2 6
R 1 2
Q 1 4
Q 2 6

Sample Output

4
4
3
4

HINT

对于100%的数据,N≤10000,M≤10000,修改操作不多于1000次,所有的输入数据中出现的所有整数均大于等于1且不超过10^6。

2016.3.2新加数据两组by Nano_Ape

题意:

查询区间颜色种数,且带修改。

代码如下:

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <string>
#include <set>
using namespace std;
typedef long long LL;
const int INF = 2e9;
const LL LNF = 9e18;
const int MOD = 1e9+;
const int MAXN = 1e6+; int val[MAXN], tmp[MAXN];
int block, sum[MAXN], Ans[MAXN];
int num1, num2; struct Node
{
//index记录查询的编号, t记录查询时执行了多少步修改
int l, r, index, t;
bool operator<(const Node&x) const{
if(l/block!=x.l/block) return l/block<x.l/block;
else if(r!=x.r) return r<x.r;
else return t<x.t;
}
}q[MAXN]; struct
{
//preCol记录修改前pos位的颜色, nowCol记录修改后pos位的颜色
int pos, nowCol, preCol;
}op[MAXN]; int L, R, T, ans;
void modifyTime(int pos, int col)
{
if(L<=pos && pos<=R)
{
sum[val[pos]]--;
if(sum[val[pos]]==) ans--;
val[pos] = col;
sum[val[pos]]++;
if(sum[val[pos]]==) ans++;
}
else val[pos] = col;
} void add(int pos)
{
sum[val[pos]]++;
if(sum[val[pos]]==) ans++;
} void del(int pos)
{
sum[val[pos]]--;
if(sum[val[pos]]==) ans--;
} void work()
{
L = , R = , T = , ans = ;
memset(sum, , sizeof(sum));
for(int i = ; i<=num1; i++)
{
while(T<q[i].t) T++, modifyTime(op[T].pos, op[T].nowCol);
while(T>q[i].t) modifyTime(op[T].pos, op[T].preCol), T--;
while(L<q[i].l) del(L), L++;
while(L>q[i].l) L--, add(L);
while(R<q[i].r) R++, add(R);
while(R>q[i].r) del(R), R--;
Ans[q[i].index] = ans;
}
} int main()
{
int n, m;
while(scanf("%d%d", &n,&m)!=EOF)
{
block = sqrt(n);
for(int i = ; i<=n; i++)
{
scanf("%d", &val[i]);
tmp[i] = val[i];
} num1 = num2 = ;
for(int i = ; i<=m; i++)
{
char s[]; int x, y;
scanf("%s%d%d", s, &x, &y);
if(s[]=='Q')
{
q[++num1].index = num1;
q[num1].t = num2;
q[num1].l = x;
q[num1].r = y;
}
else //tmp用于记录动态修改时每个位置上的颜色
{
op[++num2].pos = x;
op[num2].nowCol = y;
op[num2].preCol = tmp[x];
tmp[x] = y;
}
} sort(q+, q++num1);
work();
for(int i = ; i<=num1; i++)
printf("%d\n", Ans[i]);
}
}

直接暴力也行:

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <string>
#include <set>
using namespace std;
typedef long long LL;
const int INF = 2e9;
const LL LNF = 9e18;
const int MOD = 1e9+;
const int MAXN = 1e6+; int val[MAXN], tmp[MAXN];
int block, sum[MAXN], Ans[MAXN];
int num1, num2; struct Node
{
//index记录查询的编号, t记录查询时执行了多少步修改
int l, r, index, t;
}q[MAXN]; struct
{
//preCol记录修改前pos位的颜色, nowCol记录修改后pos位的颜色
int pos, nowCol, preCol;
}op[MAXN]; int L, R, T, ans;
void modifyTime(int pos, int col)
{
if(L<=pos && pos<=R)
{
sum[val[pos]]--;
if(sum[val[pos]]==) ans--;
val[pos] = col;
sum[val[pos]]++;
if(sum[val[pos]]==) ans++;
}
else val[pos] = col;
} void add(int pos)
{
sum[val[pos]]++;
if(sum[val[pos]]==) ans++;
} void del(int pos)
{
sum[val[pos]]--;
if(sum[val[pos]]==) ans--;
} void work()
{
L = , R = , T = , ans = ;
memset(sum, , sizeof(sum));
for(int i = ; i<=num1; i++)
{
while(T<q[i].t) T++, modifyTime(op[T].pos, op[T].nowCol);
while(T>q[i].t) modifyTime(op[T].pos, op[T].preCol), T--;
while(L<q[i].l) del(L), L++;
while(L>q[i].l) L--, add(L);
while(R<q[i].r) R++, add(R);
while(R>q[i].r) del(R), R--;
Ans[q[i].index] = ans;
}
} int main()
{
int n, m;
while(scanf("%d%d", &n,&m)!=EOF)
{
for(int i = ; i<=n; i++)
{
scanf("%d", &val[i]);
tmp[i] = val[i];
} num1 = num2 = ;
for(int i = ; i<=m; i++)
{
char s[]; int x, y;
scanf("%s%d%d", s, &x, &y);
if(s[]=='Q')
{
q[++num1].index = num1;
q[num1].t = num2;
q[num1].l = x;
q[num1].r = y;
}
else //tmp用于记录动态修改时每个位置上的颜色
{
op[++num2].pos = x;
op[num2].nowCol = y;
op[num2].preCol = tmp[x];
tmp[x] = y;
}
} work();
for(int i = ; i<=num1; i++)
printf("%d\n", Ans[i]);
}
}

BZOJ2120 数颜色 —— 待修改莫队的更多相关文章

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

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

  2. [国家集训队][bzoj2120] 数颜色 [带修改莫队]

    题面: 传送门 思路: 这道题和SDOI2009的HH的项链很像,只是多了一个修改 模板套上去呀 莫队学习请戳这里:莫队 Code: #include<iostream> #include ...

  3. BZOJ2120/洛谷P1903 [国家集训队] 数颜色 [带修改莫队]

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

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

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

  5. P1903 [国家集训队]数颜色 (带修改莫队)

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

  6. P1903 [国家集训队]数颜色 带修改莫队板子

    大概就是要多加一维time 然后按照(l的块,r的块,time)为关键字排序 转移区间修改还是按照莫队的方式(每个修改要记修改前后的状态) 然后玄学dalao告诉窝块大小设为\(O(n^{\frac{ ...

  7. bzoj2120 数颜色——带修莫队

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2120 带修改的莫队: 用结构体存下修改和询问,排好序保证时间后就全局移动修改即可: 参考了T ...

  8. COGS.1901.[模板][国家集训队2011]数颜色(带修改莫队)

    题目链接 COGS BZOJ2120 洛谷P1903 /* Add和Subd函数中的vis不能直接设为=1或=0 比如 l=1,r=0 -> l=3,r=5 时,[1,5]的vis标记全都是1 ...

  9. bzoj2120: 数颜色 带修莫队

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

随机推荐

  1. vue框架及其

    Vue常用UI框架 PC端: 1. ElementUI:http://element-cn.eleme.io/#/zh-CN 2. iView:https://www.iviewui.com/ 3. ...

  2. BZOJ1005明明的烦恼 Prufer + 分解質因數 + 高精度

    @[高精度, Prufer, 質因數分解] Description 自从明明学了树的结构,就对奇怪的树产生了兴趣......给出标号为1到N的点,以及某些点最终的度数,允许在 任意两点间连线,可产生多 ...

  3. K-L变换和 主成分分析PCA

    一.K-L变换 说PCA的话,必须先介绍一下K-L变换了. K-L变换是Karhunen-Loeve变换的简称,是一种特殊的正交变换.它是建立在统计特性基础上的一种变换,有的文献也称其为霍特林(Hot ...

  4. 赞一下TMS Software 和 AdvStringGrid

    非常久前给Support发Email问能不能在设计期给AdvStringGrid标题加个数字标识.每次我都是自己改代码加上去.这次升级到新版本号,没想到增加了这个功能: 功能虽小可是非常有用,非常多的 ...

  5. Majority Number

    题目描写叙述 链接地址 解法 算法解释 题目描写叙述 Given an array of integers, the majority number is the number that occurs ...

  6. vue2 + typescript2 自定义过滤器

    1.定义一个过滤器 // color-directive.ts import { DirectiveOptions } from 'vue' const directive: DirectiveOpt ...

  7. vue class绑定 组件

    当在一个自定义组件上使用 class 属性时,这些类将被添加到该组件的根元素上面.这个元素上已经存在的类不会被覆盖. 例如,如果你声明了这个组件: Vue.component('my-componen ...

  8. 如何去掉Google搜索的跳转 让你的Google搜索不被reset掉

    http://www.nowamagic.net/librarys/veda/detail/389 在点击google搜索结果时,google会在结果的URL前做个跳转,且有时这个跳转地址会被墙,这样 ...

  9. 数据库历险记(三) | 缓存框架的连环炮 数据库历险记(二) | Redis 和 Mecached 到底哪个好? 数据库历险记(一) | MySQL这么好,为什么还有人用Oracle? 面对海量请求,缓存设计还应该考虑哪些问题?

    数据库历险记(三) | 缓存框架的连环炮   文章首发于微信公众号「陈树义」,专注于 Java 技术分享的社区.点击链接扫描二维码,与500位小伙伴一起共同进步.微信公众号二维码 http://p3n ...

  10. Allegro布线基本操作

    转:allegro基本步骤 常见问题 cadence16.5中电源线.地线取消飞线显示 目录: 一.Allegro基本技巧 1.关闭电源和地网络的飞线 2.开启特定NET飞线 3.元器件快速对齐(待完 ...