bzoj 2453 : 维护队列 带修莫队
2453: 维护队列
Time Limit: 10 Sec Memory Limit: 128 MB
Submit: 952 Solved: 432
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 2
Q 1 2
R 1 2
Q 1 2
Sample Output
1
HINT
对于100%的数据,有1 ≤ N ≤ 10000, 1 ≤ M ≤ 10000,小朋友A不会修改超过1000次,所有颜色均用1到10^6的整数表示。
Source
把询问和修改分开排序,修改按时间排,询问以左端点所在块为第一关键字,右端点所在块为第二关键字,时间为第三关键字排序。
维护左右时间三个指针,不断修改还原。
块大小为$n^{\frac{2}{3}}$。
左指针每个询问走$n^{\frac{2}{3}}$。
右指针同理,不过要多上每次总从左走到右的复杂度,总共$n\times n^{\frac{2}{3}}+n\times n^{\frac{1}{3}}$。
时间指针每次左右端点所在块变化重新开始走,一共$n^{\frac{2}{3}}$个不同的左右块匹配数,复杂度$n\times n^{\frac{2}{3}}$.
好像块开100比较快。
(写莫队时一定要先把lr往两边移,再向中间移)
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define d 100
#define N 10005
using namespace std;
int n,m;
int c[N];
struct node
{
int l,r,t,pr;
node(){l=r=t=;}
}q[N],g[N];
int cnt1,cnt2;
bool cmp1(const node &aa,const node &bb)
{
return aa.t<bb.t;
}
int be1[N],be2[N];
bool cmp2(const node &aa,const node &bb)
{
if(be1[aa.l]==be1[bb.l])
{
if(be2[aa.r]==be2[bb.r])return aa.t<bb.t;
return aa.r<bb.r;
}
return aa.l<bb.l;
}
int ans[N];
int now[N*],cnt;
void solve()
{
int p1,p2,p;
memset(now,,sizeof(now));
now[c[]]=;cnt=;g[cnt1+].t=;
p=p1=;
p2=;
for(int i=;i<=cnt2;i++)
{
while(g[p2+].t<q[i].t)
{
p2++;
int tmp=c[g[p2].l];
g[p2].pr=tmp;
c[g[p2].l]=g[p2].r;
if(g[p2].l<=p&&g[p2].l>=p1)
{
now[tmp]--;
if(!now[tmp])cnt--;
now[g[p2].r]++;
if(now[g[p2].r]==)cnt++;
}
}
while(g[p2].t>q[i].t)
{ c[g[p2].l]=g[p2].pr;
if(g[p2].l<=p&&g[p2].l>=p1)
{
now[g[p2].r]--;
if(!now[g[p2].r])cnt--;
now[g[p2].pr]++;
if(now[g[p2].pr]==)cnt++;
}
p2--;
}
while(p<q[i].r)
{
p++;now[c[p]]++;
if(now[c[p]]==)cnt++;
}
while(p>q[i].r)
{
now[c[p]]--;if(!now[c[p]])cnt--;
p--;
}
while(p1<q[i].l)
{
now[c[p1]]--;if(!now[c[p1]])cnt--;
p1++;
}
while(p1>q[i].l)
{
p1--;now[c[p1]]++;
if(now[c[p1]]==)cnt++;
}
ans[q[i].t]=cnt;
}
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)scanf("%d",&c[i]);
for(int i=;i<=n;i++)
{
be1[i]=be2[i]=(i-)/d+;
}
memset(ans,-,sizeof(ans));
char s[];
for(int i=;i<=m;i++)
{
scanf("%s",s);
if(s[]=='R')
{
cnt1++;
scanf("%d%d",&g[cnt1].l,&g[cnt1].r);
g[cnt1].t=i;
}
else
{
cnt2++;
scanf("%d%d",&q[cnt2].l,&q[cnt2].r);
q[cnt2].t=i;
}
}
sort(q+,q+cnt2+,cmp2);
sort(g+,g+cnt1+,cmp1);
solve();
for(int i=;i<=m;i++)
{
if(ans[i]!=-)printf("%d\n",ans[i]);
}
return ;
}
bzoj 2453 : 维护队列 带修莫队的更多相关文章
- 洛谷 P1903 [国家集训队]数颜色 / 维护队列 带修莫队
题目描述 墨墨购买了一套\(N\)支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会向你发布如下指令: \(1\). \(Q\) \(L\) \(R\)代表询问你从第\(L\) ...
- Luogu P1903 [国家集训队]数颜色 / 维护队列 (带修莫队)
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> ...
- bzoj 2120 数颜色 (带修莫队)
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=2120 题意:两种操作:Q 询问区间 l - r 内颜色的种类 ,R 单点修改 思路 ...
- BZOJ 2120 数颜色 (带修莫队)
2120: 数颜色 Time Limit: 6 Sec Memory Limit: 259 MBSubmit: 6367 Solved: 2537[Submit][Status][Discuss] ...
- P1903 [国家集训队]数颜色 / 维护队列 带修改莫队
题目描述 墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会向你发布如下指令: 1. Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色的画笔. 2 ...
- luogu 1903 [国家集训队]数颜色 / 维护队列 带修改莫队
十分玄学的数据结构~ code: #include <bits/stdc++.h> #define N 1000006 #define setIO(s) freopen(s".i ...
- P1903 [国家集训队]数颜色 / 维护队列(带修莫队)
题目描述: 墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会向你发布如下指令: 1. Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色的画笔. ...
- BZOJ 4129 Haruna’s Breakfast ( 树上带修莫队 )
题面 求树上某路径上最小的没出现过的权值,有单点修改 添加链接描述 分析 树上带修莫队板题,问题是怎么求最小的没出现过的权值. 因为只有nnn个点,所以没出现过的最小值一定在[0,n][0,n][0, ...
- BZOJ 3052/Luogu P4074 [wc2013]糖果公园 (树上带修莫队)
题面 中文题面,难得解释了 BZOJ传送门 Luogu传送门 分析 树上带修莫队板子题... 开始没给分块大小赋初值T了好一会... CODE #include <bits/stdc++.h&g ...
随机推荐
- FirstWebApp
servlet规范中定义了web应用程序的目录层次:http://localhost:8080/docs/appdev/deployment.html 第一个web应用程序 开发,并部署到tomcat ...
- 【RL系列】马尔可夫决策过程中状态价值函数的一般形式
请先阅读上一篇文章:[RL系列]马尔可夫决策过程与动态编程 在上一篇文章里,主要讨论了马尔可夫决策过程模型的来源和基本思想,并以MAB问题为例简单的介绍了动态编程的基本方法.虽然上一篇文章中的马尔可夫 ...
- java内存结构JVM——java内存模型JMM——java对象模型JOM
JVM内存结构 Java代码是要运行在虚拟机上的,而虚拟机在执行Java程序的过程中会把所管理的内存划分为若干个不同的数据区域,这些区域都有各自的用途.其中有些区域随着虚拟机进程的启动而存在,而有些区 ...
- sprint2(第九天)
今天是sprint2的最后一天,已经完成功能有可以实现点餐功能.菜品的添加和删减.菜品数量的增减.添加备注.查看订单详情.订单状态.提交订单.后厨可以查看订单信息,对菜品的状态进行操作,是否完成烹饪, ...
- Scrum Meeting 10.27
1.会议内容: 姓名 今日任务 明日任务 预估时间(h) 徐越 配置SQLserver 学习本地和服务器之间的通信 4 卞忠昊 找上届代码的bug 学习安卓布局(layout)的有关知识,研究上届学长 ...
- Week4-作业1:阅读与博客
第四章.两人合作 1.原文: 在变量面前加上有意义的前缀,程序员就能一眼看出变量的类型及相应的语义.这就是“匈牙利命名法”的用处.还有一些地方不适合用“匈牙利命名法”,比如,在一些强类型的语言(如C# ...
- angularJS1笔记-(6)-自定义过滤器
html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...
- [51单片机] Keil C51中变量的使用方法详解
引言 8051内核单片机是一种通用单片机,在国内占有较大的市场份额.在将C语言用于51内核单片机的研究方面,Keil公司做得最为成功.由于51内核单片机的存储结构的特殊性,Keil C51中变量 ...
- 『编程题全队』Alpha 阶段冲刺博客Day3
1.每日站立式会议 1.会议照片 2.昨天已完成的工作统计 孙志威: 1.添加团队模块的标题栏 2.测试客户端和服务器之间的通讯基本连通性 3.完成团队模块的燃尽图模块 孙慧君: 1.完成了水印的设计 ...
- Oracle 数据库备份启用压缩以及remap
1. Oracle数据库进行备份恢复 客户测试环境, 有时候需要从现场copy到公司, 压缩虽然能够减少部分空间大小,但是copy到虚拟机里面也时浪费很大量的磁盘,所以能够在备份恢复的过程中执行压缩最 ...