原题

询问区间有种个颜色,单点修改某个位置。

修改次数<=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 维护数列 || 单点修改分块的更多相关文章

  1. BZOJ 2120 数颜色&2453 维护队列 [带修改的莫队算法]【学习笔记】

    2120: 数颜色 Time Limit: 6 Sec  Memory Limit: 259 MBSubmit: 3665  Solved: 1422[Submit][Status][Discuss] ...

  2. Bzoj 2453: 维护队列 && Bzoj 2120: 数颜色 分块,bitset

    2453: 维护队列 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 578  Solved: 247[Submit][Status][Discuss] ...

  3. bzoj 2453 : 维护队列 带修莫队

    2453: 维护队列 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 952  Solved: 432[Submit][Status][Discuss] ...

  4. bzoj 2453: 维护队列

    2453: 维护队列 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1079  Solved: 503[Submit][Status][Discuss ...

  5. BZOJ.2453.维护队列([模板]带修改莫队)

    题目链接 带修改莫队: 普通莫队的扩展,依旧从[l,r,t]怎么转移到[l+1,r,t],[l,r+1,t],[l,r,t+1]去考虑 对于当前所在的区间维护一个vis[l~r]=1,在修改值时根据是 ...

  6. BZOJ 2453 维护队列 | 分块

    题目: http://www.lydsy.com/JudgeOnline/problem.php?id=2453 题解: 考虑维护每个位置的颜色上一次出现在哪里,计为pre[i],在询问l到r的时候, ...

  7. Bzoj 2120: 数颜色 && 2453: 维护队列 莫队,分块,bitset

    2120: 数颜色 Time Limit: 6 Sec  Memory Limit: 259 MBSubmit: 2645  Solved: 1039[Submit][Status][Discuss] ...

  8. 【BZOJ 2453|bzoj 2120】 2453: 维护队列 (分块+二分)

    2453: 维护队列 Description 你小时候玩过弹珠吗? 小朋友A有一些弹珠,A喜欢把它们排成队列,从左到右编号为1到N.为了整个队列鲜艳美观,小朋友想知道某一段连续弹珠中,不同颜色的弹珠有 ...

  9. 洛谷 P2042 [NOI2005]维护数列-Splay(插入 删除 修改 翻转 求和 最大的子序列)

    因为要讲座,随便写一下,等讲完有时间好好写一篇splay的博客. 先直接上题目然后贴代码,具体讲解都写代码里了. 参考的博客等的链接都贴代码里了,有空再好好写. P2042 [NOI2005]维护数列 ...

随机推荐

  1. 在centos7云服务器上搭建Apache服务器并访问到你的网站

    使用X-shell ssh安全连接到云服务器 https://mail.qq.com/cgi-bin/mail_spam?action=check_link&url=https://www.n ...

  2. Java分享笔记:Map集合(接口)的基本方法程序演示

    package pack02; import java.util.*; public class MapDemo { public static void main(String[] args) { ...

  3. What is EJB

    What is EJB 0.什么是EJB? 答:EJB是用于构建企业应用程序模块托管的.服务器端组件架构.EJB技术加速并简化了开发基于Java技术的分布式.事务性.安全和便携的应用程序. 先看一下E ...

  4. 汇编语言编写Hello World

    ;================================= ; HELLO world DATAS segment string DB 'HELLO World','$' DATAS end ...

  5. form表单submit按钮提交页面不跳转

    方案一 <html> <body> <form action="" method="post" target="nm_i ...

  6. mysql 按值排序

    order by FIELD(AuditorStatus,3,0,1,2) laravel 写法 $data = $query->orderByRaw(\DB::Raw('FIELD(Audit ...

  7. sql语句(Oracle和sqlserver)

    查询表的首句:(Oracle) select * from (select a.*, rownum as rn from tab_name a order by col )where rn = 1 o ...

  8. iOS-cell的封装和重用

    一.通过xib描述cell---(cell的高度一致,cell里面控件布局基本一样): 1.(M) 创建模型: -------------------------------------------- ...

  9. 将WebAPI发布到本地服务器与远程服务器

    一.本地服务器 参考链接:https://blog.csdn.net/shuai_wy/article/details/69221858 1.要实现 IIS Express域名.IP的访问,关键在于需 ...

  10. Color Length UVA - 1625 DP

    题目:题目链接 题意:输入两个长度分别为n和m的颜色序列,要求按顺序合并成同一个序列,即每次可以把一个序列开头的颜色放到新序列的尾部.对于每个颜色c来说,其跨度L(c)等于最大位置和最小位置之差,输出 ...