#带修改莫队,分块#jzoj 1942 洛谷 1903 数颜色

2024-02-11 05:18

本文主要是介绍#带修改莫队,分块#jzoj 1942 洛谷 1903 数颜色,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色的画笔。 R P Col 把第P支画笔替换为颜色Col。需要满足查询


分析

这道题看起来就是要离线的,需要用莫队,但是原莫队不支持修改,那么就弄一弄,当然还要用分块优化,就没有什么了(jzoj卡逐字符输入)


代码

#include <cstdio>
#include <cmath>
#include <algorithm>
struct dif{int whe,nnw,pre;}chg[50001]; int a[50001],ans[50001];
struct qus{int l,r,whe,rk;}q[50001]; int n,m,block,color[1000001];
int in(){int ans=0; char c=getchar();while (c<48||c>57) c=getchar();while (c>47&&c<58) ans=ans*10+c-48,c=getchar();return ans;
}
void print(int ans){if (ans>9) print(ans/10); putchar(ans%10+48);}
bool cmp(const qus &a,const qus &b){if (a.l/block!=b.l/block) return a.l/block<b.l/block;//分块if (a.r/block!=b.r/block) return a.r/block<b.r/block;return a.whe<b.whe;
}
int main(){n=in(); m=in(); int tot1=0,tot2=0,l=1,r=0,Ans=0,now=0;for (register int i=1;i<=n;i++) a[i]=in();for (register int i=1;i<=m;i++){char c=getchar();while (c<65||c>90) c=getchar();if (c=='R'){chg[++tot1]=(dif){in(),in(),0};chg[tot1].pre=a[chg[tot1].whe];//前一个答案a[chg[tot1].whe]=chg[tot1].nnw;//现在的答案}else q[++tot2]=(qus){in(),in(),tot1,tot2};}block=ceil(exp((log(tot1)+log(tot2))/3));//jzojREfor (register int i=tot1;i>=1;i--) a[chg[i].whe]=chg[i].pre;std::sort(q+1,q+1+tot2,cmp);for (register int i=1;i<=tot2;i++){while (q[i].l<l) Ans+=!color[a[--l]]++;//原莫队模板while (q[i].l>l) Ans-=!--color[a[l++]];while (q[i].r>r) Ans+=!color[a[++r]]++;while (q[i].r<r) Ans-=!--color[a[r--]];while (q[i].whe<now){int k=chg[now].whe;if (l<=k&&k<=r) Ans-=!--color[a[k]];a[k]=chg[now--].pre;//修改if (l<=k&&k<=r) Ans+=!color[a[k]]++;}while (q[i].whe>now){int k=chg[++now].whe;if (l<=k&&k<=r) Ans-=!--color[a[k]];a[k]=chg[now].nnw;if (l<=k&&k<=r) Ans+=!color[a[k]]++;}ans[q[i].rk]=Ans;//离线返回}for (register int i=1;i<=tot2;i++) print(ans[i]),putchar('\n');return 0;
}

这篇关于#带修改莫队,分块#jzoj 1942 洛谷 1903 数颜色的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/698925

相关文章

Docker镜像修改hosts及dockerfile修改hosts文件的实现方式

《Docker镜像修改hosts及dockerfile修改hosts文件的实现方式》:本文主要介绍Docker镜像修改hosts及dockerfile修改hosts文件的实现方式,具有很好的参考价... 目录docker镜像修改hosts及dockerfile修改hosts文件准备 dockerfile 文

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Linux修改pip临时目录方法的详解

《Linux修改pip临时目录方法的详解》在Linux系统中,pip在安装Python包时会使用临时目录(TMPDIR),但默认的临时目录可能会受到存储空间不足或权限问题的影响,所以本文将详细介绍如何... 目录引言一、为什么要修改 pip 的临时目录?1. 解决存储空间不足的问题2. 解决权限问题3. 提

Linux文件名修改方法大全

《Linux文件名修改方法大全》在Linux系统中,文件名修改是一个常见且重要的操作,文件名修改可以更好地管理文件和文件夹,使其更具可读性和有序性,本文将介绍三种在Linux系统下常用的文件名修改方法... 目录一、引言二、使用mv命令修改文件名三、使用rename命令修改文件名四、mv命令和rename命

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu

Linux下修改hostname的三种实现方式

《Linux下修改hostname的三种实现方式》:本文主要介绍Linux下修改hostname的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下修改ho编程stname三种方式方法1:修改配置文件方法2:hFvEWEostnamectl命

Git如何修改已提交人的用户名和邮箱

《Git如何修改已提交人的用户名和邮箱》文章介绍了如何修改Git已提交人的用户名和邮箱,包括注意事项和具体步骤,确保操作正确无误... 目录git修改已提交人的用户名和邮箱前言第一步第二步总结git修改已提交人的用户名和邮箱前言需注意以下两点内容:需要在顶层目录下(php就是 .git 文件夹所在的目

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依