cogs 1901. [国家集训队2011]数颜色
Cogs 1901. [国家集训队2011]数颜色
★★★ 输入文件:nt2011_color.in 输出文件:nt2011_color.out 简单对比
时间限制:0.6 s 内存限制:512 MB
【试题来源】
【问题描述】
1、 Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色的画笔。
2、 R P Col 把第P支画笔替换为颜色Col。
为了满足墨墨的要求,你知道你需要干什么了吗?
【输入格式】
第2行N个整数,分别代表初始画笔排中第i支画笔的颜色。
第3行到第2+M行,每行分别代表墨墨会做的一件事情,格式见题干部分。
【输出格式】
【样例输入】
1 2 3 4 5 5
Q 1 4
Q 2 6
R 1 2
Q 1 4
Q 2 6
【样例输出】
4
3
4
【数据规模和约定】
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define maxn 100050
struct nodeQ{
int l,r,t,id;
}a[maxn];
struct nodeR{
int pos,x,h;
}b[maxn];
bool if_[maxn];
int bel[maxn],ai[maxn],tot,num,ans[maxn],ti[maxn*];
int n,m,size=,now;
int cmp(nodeQ x,nodeQ y){
if(bel[x.l]==bel[y.l]){
if(bel[x.r]==bel[y.r])return x.t<y.t;
return x.r<y.r;
}
return x.l<y.l;
}
inline void change(int x){
int pos=b[x].pos;
if(if_[pos]){
ti[ai[pos]]--;
if(!ti[ai[pos]])now--;
}
b[x].h=ai[pos];
ai[pos]=b[x].x;
if(if_[pos]){
if(!ti[ai[pos]])now++;
ti[ai[pos]]++;
}
}
inline void unchange(int x){
int pos=b[x].pos;
if(if_[pos]){
ti[ai[pos]]--;
if(!ti[ai[pos]])now--;
}
ai[pos]=b[x].h;
if(if_[pos]){
if(!ti[ai[pos]])now++;
ti[ai[pos]]++;
}
}
inline void update(int to,int x){
int pre=ti[ai[to]];
ti[ai[to]]+=x;
if(ti[ai[to]]==&&pre==)now--;
if(ti[ai[to]]==&&pre==)now++;
if(x==)if_[to]=true;
else if_[to]=false;
}
int main(){
//freopen("cola.txt","r",stdin);
freopen("nt2011_color.in","r",stdin);
freopen("nt2011_color.out","w",stdout);
scanf("%d%d",&n,&m);char ch[];int l,r,t;
for(int i=;i<=n;i++)scanf("%d",&ai[i]),bel[i]=(i-)/size+;
for(int i=;i<=m;i++){
scanf("%s%d%d",ch,&l,&r);
if(ch[]=='Q')a[++tot].l=l,a[tot].r=r,a[tot].t=num,a[tot].id=tot;
else b[++num].pos=l,b[num].x=r;
}
sort(a+,a+tot+,cmp);l=,r=,t=,now=;
for(int i=;i<=tot;i++){
while(t<a[i].t)t++,change(t);
while(t>a[i].t)unchange(t),t--;
while(r<a[i].r)r++,update(r,);
while(r>a[i].r)update(r,-),r--;
while(l<a[i].l)update(l,-),l++;
while(l>a[i].l)l--,update(l,);
ans[a[i].id]=now;
}
for(int i=;i<=tot;i++)printf("%d\n",ans[i]);
return ;
}
cogs 1901. [国家集训队2011]数颜色的更多相关文章
- COGS.1901.[模板][国家集训队2011]数颜色(带修改莫队)
题目链接 COGS BZOJ2120 洛谷P1903 /* Add和Subd函数中的vis不能直接设为=1或=0 比如 l=1,r=0 -> l=3,r=5 时,[1,5]的vis标记全都是1 ...
- BZOJ 2150 cogs 1861 [国家集训队2011]部落战争
题目描述 lanzerb的部落在A国的上部,他们不满天寒地冻的环境,于是准备向A国的下部征战来获得更大的领土. A国是一个M*N的矩阵,其中某些地方是城镇,某些地方是高山深涧无人居住.lanzerb把 ...
- 「洛谷1903」「BZOJ2120」「国家集训队」数颜色【带修莫队,树套树】
题目链接 [BZOJ传送门] [洛谷传送门] 题目大意 单点修改,区间查询有多少种数字. 解法1--树套树 可以直接暴力树套树,我比较懒,不想写. 稍微口胡一下,可以直接来一个树状数组套主席树,也就是 ...
- [国家集训队][bzoj2120] 数颜色 [带修改莫队]
题面: 传送门 思路: 这道题和SDOI2009的HH的项链很像,只是多了一个修改 模板套上去呀 莫队学习请戳这里:莫队 Code: #include<iostream> #include ...
- AC日记——[国家集训队2011]旅游(宋方睿) cogs 1867
[国家集训队2011]旅游(宋方睿) 思路: 树链剖分,边权转点权: 线段树维护三个东西,sum,max,min: 当一个区间变成相反数时,sum=-sum,max=-min,min=-max: 来, ...
- COGS1882 [国家集训队2011]单选错位
★ 输入文件:nt2011_exp.in 输出文件:nt2011_exp.out 简单对比时间限制:1 s 内存限制:512 MB [试题来源] 2011中国国家集训队命题答辩 [问题 ...
- 1893. [国家集训队2011]等差子序列(bitset)
★★ 输入文件:nt2011_sequence.in 输出文件:nt2011_sequence.out 简单对比时间限制:0.3 s 内存限制:512 MB [试题来源] 2011中国 ...
- happiness[国家集训队2011(吴确)]
[试题来源] 2011中国国家集训队命题答辩 [问题描述] 高一一班的座位表是个n*m的矩阵,经过一个学期的相处,每个同学和前后左右相邻的同学互相成为了好朋友.这学期要分文理科了,每个同学对于选择文科 ...
- 【BZOJ 2120】【国家集训队 2011】【数颜色】(莫队)
题目描述 墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会向你发布如下指令: 1. Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色的画笔. 2 ...
随机推荐
- P5111 zhtobu3232的线段树
P5111 zhtobu3232的线段树 维护左子树右子树的贡献和跨区间贡献 #include<bits/stdc++.h> using namespace std; typedef lo ...
- 解决webpack不能匹配post请求的问题
解决webpack不能匹配post请求的问题 webpack的dev-server只能匹配get请求,在本地做本地数据的时候会很不方便. 可以使用如下两种办法解决: 1.在webpack.config ...
- git用远程库的内容覆盖本地
git fetch --all 下载远程的库的内容到本地,不做任何的合并(怎么合并可以自己选择) git reset --hard origin/master 撤销本地.暂存区.版本库(用远程服务器的 ...
- zabbix 上 mysql 优化
摘自: https://segmentfault.com/a/1190000001638101
- python的上下文管理器-1
reference:https://zhuanlan.zhihu.com/p/26487659 来看看如何正确关闭一个文件. 普通版: def m1(): f = open("output. ...
- RQNOJ 622 最小重量机器设计问题:dp
题目链接:https://www.rqnoj.cn/problem/622 题意: 一个机器由n个部件组成,每一种部件都可以从m个不同的供应商处购得. w[i][j]是从供应商j处购得的部件i的重量, ...
- bootstrap框架日期时间之年月选择及汉化
==>上次介绍了bootstrap框架日期时间 开始日期和结束日期选择 http://www.cnblogs.com/wjqblogs/p/4043198.html 今天又做了个只选择年月的日期 ...
- poj1733 Parity game[带权并查集or扩展域]
地址 连通性判定问题.(具体参考lyd并查集专题该题的转化方法,反正我菜我没想出来).转化后就是一个经典的并查集问题了. 带权:要求两点奇偶性不同,即连边权为1,否则为0,压缩路径时不断异或,可以通过 ...
- poj3709 K-Anonymous Sequence[贪心+斜率优化dp]
地址 n个数,可进行把一个数减小的操作,代价为减小的值.现求使数列任意一个数都存在至少k-1个数和他相同,问操作的最小代价. 可以先考虑最小的数,由于只能减,所以必须得至少k-1个数减为最小数,贪心策 ...
- VirtualBox文件系统已满--磁盘扩容
第1步:为virtualbox虚拟电脑扩容 进入命令行,以Windows系统为例 (特别注意空格和中文) 1.启动CMD命令行,进入VirtualBox的安装目录.如 运行:cmd C:\Users\ ...