[bzoj] 2453 维护数列 || 单点修改分块
原题
询问区间有种个颜色,单点修改某个位置。
修改次数<=1000
维护pre[i]为前一个与当前位置颜色一样的位置。
询问时以pre为关键字sort,lower_bound找pre<x的就是当前区间的答案
因为修改次数少,所以每次重新搞就行。
#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 10010
#define B 100
#define bel(x) ((x-1)/B+1)
#define st(x) ((x-1)*B+1)
#define ed(x) (x==bel(n)?n:(x*B))
using namespace std;
int n,q,a[N],pre[N],spre[N],lst[N*100],x,y;
char op[3];
int read()
{
int ans=0,fu=1;
char j=getchar();
for (;j<'0' || j>'9';j=getchar()) if (j=='-') fu=-1;
for (;j>='0' && j<='9';j=getchar()) ans*=10,ans+=j-'0';
return ans*fu;
}
int query(int x,int y)
{
int ret=0;
if (bel(x)==bel(y))
{
for (int i=x;i<=y;i++)
if (pre[i]<x) ret++;
return ret;
}
for (int i=x;i==x || i%B!=1;i++)
if (pre[i]<x) ret++;
for (int i=y;i==y || i%B!=0;i--)
if (pre[i]<x) ret++;
for (int i=bel(x)+1;i<bel(y);i++)
ret+=lower_bound(spre+st(i),spre+ed(i)+1,x)-(spre+st(i));
return ret;
}
void build()
{
memset(lst,0,sizeof(lst));
for (int i=1;i<=n;i++)
spre[i]=pre[i]=lst[a[i]],lst[a[i]]=i;
for (int i=1;i<=bel(n);i++)
sort(spre+st(i),spre+ed(i)+1);
}
void change()
{
for (int i=1;i<=n;i++) lst[a[i]]=0;
a[x]=y;
for (int i=1;i<=n;i++)
{
int t=pre[i];
pre[i]=lst[a[i]];
if (t!=pre[i])
{
for(int j=st(bel(i));j<=ed(bel(i));j++)
spre[j]=pre[j];
sort(spre+st(bel(i)),spre+ed(bel(i))+1);
}
lst[a[i]]=i;
}
}
int main()
{
n=read();
q=read();
for (int i=1;i<=n;i++) a[i]=read();
build();
while (q--)
{
scanf("%s",op);
x=read();y=read();
if (op[0]=='Q') printf("%d\n",query(x,y));
else change();
}
return 0;
}
[bzoj] 2453 维护数列 || 单点修改分块的更多相关文章
- BZOJ 2120 数颜色&2453 维护队列 [带修改的莫队算法]【学习笔记】
2120: 数颜色 Time Limit: 6 Sec Memory Limit: 259 MBSubmit: 3665 Solved: 1422[Submit][Status][Discuss] ...
- Bzoj 2453: 维护队列 && Bzoj 2120: 数颜色 分块,bitset
2453: 维护队列 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 578 Solved: 247[Submit][Status][Discuss] ...
- bzoj 2453 : 维护队列 带修莫队
2453: 维护队列 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 952 Solved: 432[Submit][Status][Discuss] ...
- bzoj 2453: 维护队列
2453: 维护队列 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1079 Solved: 503[Submit][Status][Discuss ...
- BZOJ.2453.维护队列([模板]带修改莫队)
题目链接 带修改莫队: 普通莫队的扩展,依旧从[l,r,t]怎么转移到[l+1,r,t],[l,r+1,t],[l,r,t+1]去考虑 对于当前所在的区间维护一个vis[l~r]=1,在修改值时根据是 ...
- BZOJ 2453 维护队列 | 分块
题目: http://www.lydsy.com/JudgeOnline/problem.php?id=2453 题解: 考虑维护每个位置的颜色上一次出现在哪里,计为pre[i],在询问l到r的时候, ...
- Bzoj 2120: 数颜色 && 2453: 维护队列 莫队,分块,bitset
2120: 数颜色 Time Limit: 6 Sec Memory Limit: 259 MBSubmit: 2645 Solved: 1039[Submit][Status][Discuss] ...
- 【BZOJ 2453|bzoj 2120】 2453: 维护队列 (分块+二分)
2453: 维护队列 Description 你小时候玩过弹珠吗? 小朋友A有一些弹珠,A喜欢把它们排成队列,从左到右编号为1到N.为了整个队列鲜艳美观,小朋友想知道某一段连续弹珠中,不同颜色的弹珠有 ...
- 洛谷 P2042 [NOI2005]维护数列-Splay(插入 删除 修改 翻转 求和 最大的子序列)
因为要讲座,随便写一下,等讲完有时间好好写一篇splay的博客. 先直接上题目然后贴代码,具体讲解都写代码里了. 参考的博客等的链接都贴代码里了,有空再好好写. P2042 [NOI2005]维护数列 ...
随机推荐
- LeetCode47.Permutations II(剑指offer38-1)
Given a collection of numbers that might contain duplicates, return all possible unique permutations ...
- C#基础-异常处理与自定义异常
异常处理 static void Main(string[] args) { Console.WriteLine("请输入一个数字:"); try { // 监测可能出现异常代码 ...
- linux特殊权限位suid
特殊权限位基本说明(了解): linux系统基本权限位为9位权限,但还有额外3位权限位,共12位权限: suid s(x) S 4 用户对应的权限位(用户对应的3位 ...
- C++ Primer 学习笔记_Chapter4 数组和指针–指针
一.什么是指针? 指针与迭代器一样,指针提供对其所指对象的间接访问,指针保存的是另一个对象的地址: string s("hello"); string *ps = &s; ...
- 传输控制协议(TCP)
传输控制协议(TCP)[来自Unix网络编程(卷一)第2章] 1.TCP是一个面向连接.可靠性的传输协议: 2.TCP含有用于动态估算客户与服务器之间往返时间(RTT)的算法,以便它知道等待一个确认需 ...
- PHP 代码规范、流程规范、git规范
1. 命名规范 (1).变量命名规范 1.变量使用驼峰命名法 禁止使用拼音或者拼音加数字 2.变量也应具有描述性,杜绝一切拼音.或拼音英文混杂的命名方式 3.变量包数字.字母和下划线字符,不允许使用其 ...
- POJ 2084 Catalan
Game of Connections Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 8772 Accepted: 43 ...
- 分离链接法(Separate Chaining)
之前我们说过,对于需要动态维护的散列表 冲突是不可避免的,无论你的散列函数设计的有多么精妙.因此我们解决的重要问题就是:一旦发生冲突,我们该如何加以排解? 我们在这里讨论最常见的两种方法:分离链接法和 ...
- POJ:1995-Raising Modulo Numbers(快速幂)
Raising Modulo Numbers Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 9512 Accepted: 578 ...
- ABAP自定义截取字符串长度函数
SAP 中strlen()只能计算字符串的个数,不能计算含有中文字符串的长度,如字符串“SAP大波霸”,strlen('SAP大波霸') = 6,其实真实长度为3+3*2 = 9.我们可以通过cl_a ...