#带修改莫队,分块#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

相关文章

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

如何在运行时修改serialVersionUID

优质博文:IT-BLOG-CN 问题 我正在使用第三方库连接到外部系统,一切运行正常,但突然出现序列化错误 java.io.InvalidClassException: com.essbase.api.base.EssException; local class incompatible: stream classdesc serialVersionUID = 90314637791991

android系统源码12 修改默认桌面壁纸--SRO方式

1、aosp12修改默认桌面壁纸 代码路径 :frameworks\base\core\res\res\drawable-nodpi 替换成自己的图片即可,不过需要覆盖所有目录下的图片。 由于是静态修改,则需要make一下,重新编译。 2、方法二Overlay方式 由于上述方法有很大缺点,修改多了之后容易遗忘自己修改哪些文件,为此我们采用另外一种方法,使用Overlay方式。

hibernate修改数据库已有的对象【简化操作】

陈科肇 直接上代码: /*** 更新新的数据并并未修改旧的数据* @param oldEntity 数据库存在的实体* @param newEntity 更改后的实体* @throws IllegalAccessException * @throws IllegalArgumentException */public void updateNew(T oldEntity,T newEntity

SW - 引入第三方dwg图纸后,修改坐标原点

文章目录 SW - 引入第三方dwg图纸后,修改坐标原点概述笔记设置图纸新原点END SW - 引入第三方dwg图纸后,修改坐标原点 概述 在solidworks中引入第三方的dwg格式图纸后,坐标原点大概率都不合适。 全图自动缩放后,引入的图纸离默认的原点位置差很多。 需要自己重新设置原点位置,才能自动缩放后,在工作区中间显示引入的图纸。 笔记 将dwg图纸拖到SW中

linux下修改系统日期与时间

cp /usr/share/zoneinfo/Asia/Shanghai  /etc/localtime

Windows11电脑上自带的画图软件修改照片大小(不裁剪尺寸的情况下)

针对一张图片,有时候上传的图片有大小限制,那么在这种情况下如何修改其大小呢,在不裁剪尺寸的情况下 步骤如下: 1.选定一张图片,右击->打开方式->画图,如下: 第二步:打开图片后,我们可以看到图片的大小为82.1kb,点击上面工具栏的“重设大小和倾斜”进行调整,如下: 第三步:修改水平和垂直的数字,此处我修改为分别都修改为50,然后保存,可以看到大小变成63.5kb,如下:

【第0007页 · 数组】数组中重复的数据(如何实现数组的原地修改)

【前言】本文以及之后的一些题解都会陆续整理到目录中,若想了解全部题解整理,请看这里: 第0007页 · 数组中重复的数据         今天,我们来看一个在实际工作中运用不多,但是对于一些算法题还是有必要的奇技淫巧——数组的原地修改。下面我们将通过两道题目来学习这种技巧。 【找到所有数组中消失的数】 给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1,

渐变颜色填充

GradientFill函数可以对特定的矩形区域或者三角形区域进行渐变颜色的填充。我们先来看看GradientFill函数到底长得什么样子,帅不帅。 [cpp]  view plain copy print ? BOOL GradientFill(     _In_  HDC hdc,     _In_  PTRIVERTEX pVertex,     _In_  ULONG

转:android ro.debuggable属性调试修改(mprop逆向)

android ro属性调试修改(mprop逆向)      大家都知道如果需要调试android 的程序,以下两个条件满足一个就行。第一是apk的配置文件内的AndroidManifest.xml的 android:debuggable=”true”,第二就是/default.prop中ro.debuggable=1。两种方式第一种通常是解包添加属性再打包,随着加壳软件以及apk校验等,容易出