当前位置: 首页 > news >正文

P1903 【模板】带修莫队 / [国家集训队] 数颜色 / 维护队列

题目描述

墨墨购买了一套 \(N\) 支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问。墨墨会向你发布如下指令:

  1. \(Q\ L\ R\) 代表询问你从第 \(L\) 支画笔到第 \(R\) 支画笔中共有几种不同颜色的画笔。

  2. \(R\ P\ C\) 把第 \(P\) 支画笔替换为颜色 \(C\)

为了满足墨墨的要求,你知道你需要干什么了吗?

输入格式

\(1\) 行两个整数 \(N\)\(M\),分别代表初始画笔的数量以及墨墨会做的事情的个数。

\(2\)\(N\) 个整数,分别代表初始画笔排中第 \(i\) 支画笔的颜色。

\(3\) 行到第 \(2+M\) 行,每行分别代表墨墨会做的一件事情,格式见题干部分。

输出格式

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

输入输出样例 #1

输入 #1

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

输出 #1

4
4
3
4

说明/提示

对于30%的数据,\(n,m \leq 10000\)

对于60%的数据,\(n,m \leq 50000\)

对于所有数据,\(n,m \leq 133333\)

所有的输入数据中出现的所有整数均大于等于 \(1\) 且不超过 \(10^6\)

本题可能轻微卡常数

来源:bzoj2120

本题数据为洛谷自造数据,使用 CYaRon 耗时5分钟完成数据制作。

题解

#include <bits/stdc++.h>
using namespace std;
const int N=2e5+10;
const int MAXV = 1e6+10;typedef long long ll;
int n,m;
struct Node
{ll l,r,i,t;
}q[N];struct Upd
{int pos,val;
}upd[N];ll cnt[MAXV];
ll cl=1,cr=0,ct=0;
ll kind = 0;
ll a[N];
int blen;
int bi[N];
ll ans[N];int cntq,cntu;bool cmp(Node a,Node b)
{if(bi[a.l]!=bi[b.l])return bi[a.l]<bi[b.l];if(bi[a.r]!=bi[b.r])return bi[a.r]<bi[b.r];return a.t<b.t;
}void build()
{blen = max(1,(int)pow(n,2.0/3));for(int i=1;i<=n;i++){bi[i] = (i-1)/blen +1;}sort(q+1,q+1+cntq,cmp);}void add(int x)
{if(++cnt[x]==1)kind++;
}void sub(int x)
{if(--cnt[x]==0)kind--;
}void moveT(int jobl,int jobr,int tim)
{int pos = upd[tim].pos;int val = upd[tim].val;if(jobl<=pos&&pos<=jobr){sub(a[pos]);add(val);}int tmp = a[pos];a[pos] = val;upd[tim].val = tmp;
}void solve()
{cin>>n>>m;for(int i=1;i<=n;i++){cin>>a[i];}for(int i=1;i<=m;i++){char op;int l,r,v,pos;cin>>op;if(op=='Q'){cin>>l>>r;cntq++;q[cntq].l = l;q[cntq].r = r;q[cntq].t = cntu;q[cntq].i = cntq;}else{cin>>pos>>v;cntu++;upd[cntu].pos = pos;upd[cntu].val = v;}}build();for(int i=1;i<=cntq;i++){int l = q[i].l;int r = q[i].r;int id = q[i].i;int tt = q[i].t;while(cl>l){add(a[--cl]);}while(cr<r){add(a[++cr]);}while(cl<l){sub(a[cl++]);}while(cr>r){sub(a[cr--]);}while(ct<tt){moveT(l,r,++ct);}while(ct>tt){moveT(l,r,ct--);}ans[id] = kind; }for(int i=1;i<=cntq;i++){cout<<ans[i]<<'\n';}}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int t=1;// cin>>t;while(t--){solve();}return 0;
}
http://www.jsqmd.com/news/54405/

相关文章:

  • P1883 【模板】三分 / 函数
  • CSP2025 T4
  • Day5 Scrum冲刺博客
  • 台达变频器与西门子1200 PLC互联借Modbus RTU转Profinet推动工业物联网
  • 2025-11-28
  • Convolutional Neutral Network(CNN网络)
  • 二维偏序(离线二维数点)
  • Product Hunt 每日热榜 | 2025-10-30 - 教程
  • 2025年Q4球墨铸铁管厂家TOP5排行榜:场景适配+成本优化,采购选型指南
  • 2025年Q4中国GEO优化公司权威排行榜:TOP5服务商解锁Deepseek高转化,AI搜索营销新标杆
  • WPF的MVVM模式核心架构与达成细节
  • 2025年12月GPU平台哪家好?权威榜单TOP5 低延迟+动态扩容,企业/开发者核心推荐
  • 敏捷冲刺随笔-2
  • 2025年12月高压固态软启动柜厂家排行榜,技术创新+24小时售后,工业采购测评推荐
  • 力扣160 相交链表 java达成
  • `train_test_split` 是什么?
  • 解决LVGL与FATFS编码格式冲突及外挂字库方案
  • 我是如何用浏览器插件轻松抓取抖音评论并实现精准搜索分析的
  • 重练算法(代码随想录版) day24 - 回溯part3
  • useEffect详解
  • 详解np.random.normal(0, 3, size=x.shape)
  • 代码随想录Day23_回溯_组合.md
  • 详细介绍:【JUnit实战3_21】第十二章:JUnit 5 与主流 IDE 的集成 + 第十三章:用 JUnit 5 做持续集成(上):在本地安装 Jenkins
  • 代码随想录Day24_回溯_复原IP.md
  • 何以为生
  • GraphRAG进阶:基于Neo4j与LlamaIndex的DRIFT搜索实现详解
  • Gemini3疯了!0.09接入Nano Banana Pro 4k画质API(附实战教程)
  • 11/28
  • noip板子
  • Webstorm常用配置