cf962 (Div. 3):C.sort(前缀和)

问题

给您两个长度为 𝑛n 的字符串 𝑎a 和 𝑏b 。然后,您(被迫)回答 𝑞q 个问题。

对于每个查询,你都会得到一个由 𝑙l 和 𝑟r 限定的范围。在一次操作中,您可以选择一个整数 𝑖i ( 𝑙≤𝑖≤𝑟l≤i≤r ) 和集合 𝑎𝑖=𝑥ai=x ,其中 𝑥x 是您想要的任何字符。输出必须执行的最少操作数,以便 𝚜𝚘𝚛𝚝𝚎𝚍(𝚊[𝚕..𝚛])=𝚜𝚘𝚛𝚝𝚎𝚍(𝚋[𝚕..𝚛])sorted(a[l..r])=sorted(b[l..r]) 。**对一个查询执行的操作不会影响其他查询。

对于任意字符串 𝑐c , 𝚜𝚘𝚛𝚝𝚎𝚍(𝚌[𝚕..𝚛])sorted(c[l..r]) 表示由按词典顺序排列的字符 𝑐𝑙,𝑐𝑙+1,...,𝑐𝑟cl,cl+1,...,cr 组成的子串。

输入

第一行包含 𝑡t ( 1≤𝑡≤10001≤t≤1000 )--测试用例数。( 1≤𝑡≤10001≤t≤1000 ) - 测试用例的数量。

每个测试用例的第一行包含两个整数 𝑛n 和 𝑞q ( 1≤𝑛,𝑞≤2⋅1051≤n,q≤2⋅105 ) - 两个字符串的长度和查询次数。

下面一行包含长度为 𝑛n 的 𝑎a 。可以保证 𝑎a 只包含小写拉丁字母。

下面一行包含长度为 𝑛n 的 𝑏b 。保证 𝑏b 只包含小写拉丁字母。

下面的 𝑞q 行包含两个整数 𝑙l 和 𝑟r ( 1≤𝑙≤𝑟≤𝑛1≤l≤r≤n ) - 查询范围。

保证所有测试用例中的 𝑛n 和 𝑞q 之和不超过 2⋅1052⋅105 。

输出

对于每个查询,在新行中输出一个整数,即需要执行的最少操作数。

做法

题目大意就是给你两个字符串,然后问你在某个区间内,修改几次能让这一区间排完序后完全相同。对于一个区间,两个字符串完全相同,26个字母的个数都要相同。我们就对两个串分别求前缀和,然后看26个字母个数的差异,然后除以二就是答案了。

#include<bits/stdc++.h>
using namespace std;
int t,n,q;
string a,b;
int qzh1[30][200010],qzh2[30][200010];
int main(){scanf("%d",&t);while(t--){scanf("%d%d",&n,&q);cin>>a>>b;for(int j=0;j<26;j++){for(int i=1;i<=n;i++){if(a[i-1]-'a'==j) qzh1[j][i]=qzh1[j][i-1]+1;else qzh1[j][i]=qzh1[j][i-1];if(b[i-1]-'a'==j) qzh2[j][i]=qzh2[j][i-1]+1;else qzh2[j][i]=qzh2[j][i-1];}}while(q--){int l,r;scanf("%d%d",&l,&r);int ans=0;for(int i=0;i<26;i++){ans+=abs(qzh1[i][r]-qzh1[i][l-1]-qzh2[i][r]+qzh2[i][l-1]);}cout<<ans/2<<endl;}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/876644.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux——简介

Linux的组成 Linux系统一般由四个主要部分组成&#xff1a;内核、shell、文件系统和应用程序。 内核&#xff1a;是操作系统的核心&#xff0c;负责管理系统的进程、内存、设备驱动程序、文件和网络系统等&#xff0c;决定着系统的性能和稳定性。shell&#xff1a;是系统的用…

2024:Qt--编译配置Protobuf(windows10) 配图详解

这里写自定义目录标题 一、准备1、Window10系统2、Qt Creator 5.0.2 Based on Qt 5.15.2 (MSVC 2019, 64 bit)3、protobuf-3.15.0&#xff08;本示例使用版本&#xff09;4、cmake-3.21.3-windows-x86_64&#xff08;本示例使用&#xff0c;下载的zip直接解压使用&#xff09; …

自编码器(autoencoder)

1.自编码器的由来 最初的自编码器是用来降维的&#xff0c;后来也逐渐用于去噪、生成任务。 2.自编码器的基本结构 自编码器&#xff08;autoencoder&#xff09;内部有一个隐藏层 h&#xff0c;可以产生编码&#xff08;code&#xff09;表示输入。该网络可以看作由两部分组…

ArcGIS Desktop使用入门(四)——ArcMap软件彻底卸载删除干净

系列文章目录 ArcGIS Desktop使用入门&#xff08;一&#xff09;软件初认识 ArcGIS Desktop使用入门&#xff08;二&#xff09;常用工具条——标准工具 ArcGIS Desktop使用入门&#xff08;二&#xff09;常用工具条——编辑器 ArcGIS Desktop使用入门&#xff08;二&#x…

支持向量机回归及其应用(附Python 案例代码)

使用支持向量机回归估计房价 让我们看看如何使用支持向量机&#xff08;SVM&#xff09;的概念构建一个回归器来估计房价。我们将使用sklearn中提供的数据集&#xff0c;其中每个数据点由13个属性定义。我们的目标是根据这些属性估计房价。 引言 支持向量回归&#xff08;SV…

vim的使用及退出码(return 0)

linux基础之vim快速入门 linux基础之vim快速入门_基本linux vim-CSDN博客https://blog.csdn.net/ypxcan/article/details/119878137?ops_request_misc&request_id&biz_id102&utm_termvim%E7%BC%96%E8%BE%91%E5%99%A8%E5%A4%8D%E5%88%B6%E7%B2%98%E8%B4%B4%E4%BA%…

Java(十)——接口

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 ⚡开源项目&#xff1a; rich-vue3 &#xff08;基于 Vue3 TS Pinia Element Plus Spring全家桶 MySQL&#xff09; &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;正逐渐往全干发展 &#x1…

JAVA零基础学习3(Scanner类,字符串,StringBuilder,StringJoinder,ArrayList成员方法)

JAVA零基础学习&#xff13; Scanner类输入示例代码代码解释完整代码1. 读取字符串2. 读取整数3. 读取浮点数4. 读取布尔值5. 读取单个单词6. 读取长整型数7. 读取短整型数8. 读取字节数注意事项总结 API 字符串解释示例解释解决方法示例&#xff1a;使用 StringBuilder String…

口碑爆棚的高分法国电影,一起在光影中领略法式魅力吧!

文章目录 引言《与玛格丽特的午后》(网友评分:9.1)《午夜巴黎》(网友评分:8.3)《玫瑰人生》(网友评分:8.4)《双姝奇缘》(网友评分:8.7)《巴黎淘气帮》(网友评分:8.6)《触不可及》(网友评分:9.3)《爱在日落黄昏时》(网友评分:8.9)《悲惨世界》(网友评分:…

VScode使用Github Copilot插件时出现read ECONNREST问题的解决方法

文章目录 read ECONNREST查看是否仍是 Copilot 会员查看控制台输出网络连接问题浏览器设置问题笔者的话 read ECONNREST 最近使用 Copilot 时一直出现 read ECONNREST 问题&#xff0c;这个表示连接被对方重置了&#xff0c;就是说在读取数据时连接被关闭。 我首先怀疑是不是…

[023-2].第2节:SpringBoot中接收参数相关注解

我的后端学习大纲 SpringBoot学习大纲 1.1.基本介绍&#xff1a; SpringBoot接收客户端提交的数据、参数会使用的一些注解&#xff1a; 1.PathVarible2. RequestHeader3.RequestParam4.CookieValue5.RequestBody6.RequestAttribute 1.2.接收参数相关注解与应用实例&#xff1a;…

无人机制造工艺流程详解

一、需求分析 无人机制造的第一步是需求分析。这一阶段主要明确无人机的使用场景、功能要求、性能指标以及成本预算等。通过与客户或项目团队的深入沟通&#xff0c;确保对无人机的需求有全面而准确的理解。同时&#xff0c;也需要进行市场调研&#xff0c;了解同类型产品的特…

科普文:docker基础概念、软件安装和常用命令

docker基本概念 一 容器的概念 1. 什么是容器&#xff1a;容器是在隔离的环境里面运行的一个进程&#xff0c;这个隔离的环境有自己的系统目录文件&#xff0c;有自己的ip地址&#xff0c;主机名等。也可以说&#xff1a;容器是一种轻量级虚拟化的技术。 2. 容器相对于kvm虚…

如何使用 SQLite ?

SQLite 是一个轻量级、嵌入式的关系型数据库管理系统&#xff08;RDBMS&#xff09;。它是一种 C 库&#xff0c;实现了自给自足、无服务器、零配置、事务性 SQL 数据库引擎。SQLite 的源代码是开放的&#xff0c;完全在公共领域。它被广泛用于各种应用程序&#xff0c;包括浏览…

【C语言】函数的递归

目录 一、什么是递归 二、递归的思想 三、递归的限制条件 四、递归中的栈溢出 五、递归举例 &#xff08;1&#xff09;例1&#xff1a;n的阶乘 &#xff08;2&#xff09;例子2&#xff1a;顺序打印一个数的每一位 六、递归和迭代 七、拓展题目 &#xff08;1&#…

Chainlit一个快速构建成式AI应用的Python框架,无缝集成与多平台部署

概述 Chainlit 是一个开源 Python 包&#xff0c;用于构建和部署生成式 AI 应用的开源框架。它提供了一种简单的方法来创建交互式的用户界面&#xff0c;这些界面可以与 LLM&#xff08;大型语言模型&#xff09;驱动的应用程序进行通信。Chainlit 旨在帮助开发者快速构建基于…

如何知道一个字段在selenium中是否可编辑?

这篇文章将检查我们如何使用Java检查selenium webdriver中的字段是否可编辑。 我们如何知道我们是否可以编辑字段&#xff1f;“readonly”属性控制字段的可编辑性。如果元素上存在“readonly”属性&#xff0c;则无法编辑或操作该元素或字段。 因此&#xff0c;如果我们找到一…

强大的开源网络攻击面分析工具:Hetty

Hetty&#xff1a;深入网络的每一个角落&#xff0c;Hetty让安全漏洞无处遁形。- 精选真开源&#xff0c;释放新价值。 概览 Hetty作为一个专为网络攻击面分析而设计的开源HTTP/1.1客户端&#xff0c;其设计初衷是为了帮助安全研究人员和渗透测试人员深入挖掘潜在的网络漏洞。…

[网鼎杯 2020 朱雀组]Nmap(详细解读版)

这道题考察nmap的一些用法,以及escapeshellarg和escapeshellcmd两个函数的绕过&#xff0c;可以看这里PHP escapeshellarg()escapeshellcmd() 之殇 (seebug.org) 两种解题方法&#xff1a; 第一种通过nmap的-iL参数读取扫描一个文件到指定文件中第二种是利用nmap的参数写入we…

NTC测温

前言 假设已知ad-温度转换表ad_table[100]; 数组元素ad_table[0] ~ ad_table[99] 对应温度0 ~ 99℃&#xff1b;已知MCU检测到NTC两端电压ad值位temp_ad,请写出将temp_ad转换成温度值的程序代码&#xff0c;要求温度值精确到0.1℃ 代码 为了将AD值转换为精确到0.1℃的温度值…