csp信奥赛C++高频考点专项训练之字符串 --【字符统计】:「MYOI-R3」字符串

csp信奥赛C++高频考点专项训练之字符串 --【字符统计】:「MYOI-R3」字符串

题目描述

给定字符串 s , t s,t s,t。

现在你要在 s , t s,t s,t 中删除一些字符并将它们重新排列使 s = t s=t s=t。

问操作后的 ∣ s ∣ |s| ∣s∣(即字符串 s s s 的长度)最大是多少?

输入格式

第一行一个字符串 s s s。

第二行一个字符串 t t t。

输出格式

一行一个整数,表示操作后的 ∣ s ∣ |s| ∣s∣ 的最大值。

输入输出样例 1
输入 1
复制代码
abc
bc
输出 1
复制代码
2
输入输出样例 2
输入 2
复制代码
aaaaa
bbbbb
输出 2
复制代码
0
说明/提示

在第一个样例中,将 a 删除,留下 bc

此时 ∣ s ∣ = 2 |s|=2 ∣s∣=2,可以证明这是最优解。

在第二个样例中,将 aaaaa 删除,留下空串。

bbbbb 删除,留下空串。

此时 ∣ s ∣ = 0 |s|=0 ∣s∣=0,可以证明这是最优解。

本题采用捆绑测试

记 n = max ⁡ ( ∣ s ∣ , ∣ t ∣ ) n=\max(|s|,|t|) n=max(∣s∣,∣t∣)。

Subtask \text{Subtask} Subtask n\\le 特殊性质 总分值
1 1 1 10 10 10 25 25 25
2 2 2 10 5 10^5 105 A \text{A} A 25 25 25
3 3 3 10 5 10^5 105 B \text{B} B 25 25 25
4 4 4 10 5 10^5 105 25 25 25

对于 100 % 100\% 100% 的数据, 1 ≤ ∣ s ∣ , ∣ t ∣ ≤ 10 5 1 \le |s|,|t| \le 10^5 1≤∣s∣,∣t∣≤105,字符串均由小写字母组成。

特殊性质 A \text{A} A: s s s 是一个 a ∼ z \text{a}\sim\text{z} a∼z 的排列。

特殊性质 B \text{B} B:保证 s i , t i ∈ { a , b } s_i,t_i\in\{\text{a},\text{b} \} si,ti∈{a,b}。

思路分析

题目要求:删除两个字符串中的部分字符,并重新排列剩下的字符,使得两个字符串相等。由于可以任意重排,最终字符串的字符组成只取决于两个字符串中字符出现的频数。对于每个字符,能保留的最大数量就是两个字符串中该字符出现次数的最小值。因此,答案等于所有字符的 min(cnt_s[ch], cnt_t[ch]) 之和。

实现步骤:

  1. 读入字符串 st
  2. 用两个长度为 26 的数组 ab 分别统计 st 中每个字母出现的次数。
  3. 遍历 26 个字母,累加 min(a[i], b[i]) 到答案。
  4. 输出答案。

时间复杂度 O(|s|+|t|),空间 O(1)。

代码实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

string s,t;//两个输入字符串
int a[26];//桶a:统计s中每个字母出现次数
int b[26];//桶b:统计t中每个字母出现次数
int ans=0;//最终能得到的字符串长度

int main(){
    cin>>s>>t;//读入字符串
    //统计s中每个字母的出现次数
    for(int i=0;i<s.size();i++){
        a[s[i]-'a']++;//将字符转换为0~25的下标并累加
    }
    //统计t中每个字母的出现次数
    for(int i=0;i<t.size();i++){
        b[t[i]-'a']++;
    }
    //累加每个字母的最小出现次数
    for(int i=0;i<26;i++){
        ans+=min(a[i],b[i]);//取较小值并累加
    }
    cout<<ans;//输出结果
    return 0;
}

功能分析

  • 输入处理 :从标准输入读取两个字符串 st
  • 频数统计 :使用两个整型数组 ab 分别记录 st 中每个小写字母('a'~'z')出现的次数。通过 字符 - 'a' 将字符映射到数组下标。
  • 答案计算 :遍历 26 个字母,将两个数组对应位置的最小值累加到 ans
  • 输出结果 :打印 ans,即操作后字符串的最大可能长度。

该算法正确解决了问题,时间复杂度 O(|s|+|t|),空间复杂度 O(1),满足题目数据范围(|s|,|t| ≤ 10^5),可通过所有测试点。


【完整系列请查看专栏】:
信奥赛C++普及组CSP-J一等奖通关刷题题单及题解:
https://blog.csdn.net/weixin_66461496/category_12673810.html 点击跳转


各种学习资料,助力大家一站式学习和提升!!!

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	cout<<"##########  一站式掌握信奥赛知识!  ##########";
	cout<<"#############  冲刺信奥赛拿奖!  #############";
	cout<<"######  课程购买后永久学习,不受限制!   ######";
	return 0;
}

【秘籍汇总】(完整csp信奥赛C++学习资料):

1、csp/信奥赛C++,完整信奥赛系列课程(永久学习):

https://edu.csdn.net/lecturer/7901 点击跳转

2、CSP信奥赛C++竞赛拿奖视频课:

https://edu.csdn.net/course/detail/40437 点击跳转

https://edu.csdn.net/course/detail/41081 点击跳转

3、csp信奥赛高频考点知识详解及案例实践:

CSP信奥赛C++动态规划:
https://blog.csdn.net/weixin_66461496/category_13096895.html点击跳转

CSP信奥赛C++标准模板库STL:
https://blog.csdn.net/weixin_66461496/category_13108077.html 点击跳转

信奥赛C++提高组csp-s知识详解及案例实践:
https://blog.csdn.net/weixin_66461496/category_13113932.html 点击跳转

4、csp信奥赛冲刺一等奖有效刷题题解:

信奥赛C++普及组CSP-J一等奖通关刷题题单及题解:
https://blog.csdn.net/weixin_66461496/category_12673810.html 点击跳转

信奥赛C++提高组csp-j初赛&复赛真题题解(持续更新): https://blog.csdn.net/weixin_66461496/category_12808781.html 点击跳转

信奥赛C++提高组csp-s初赛&复赛真题题解(持续更新):
https://blog.csdn.net/weixin_66461496/category_13125089.html 点击跳转

5、GESP C++考级真题题解:

GESP(C++ 一级+二级+三级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12858102.html 点击跳转

GESP(C++ 四级+五级+六级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12869848.html 点击跳转

GESP(C++ 七级+八级)真题题解(持续更新):
https://blog.csdn.net/weixin_66461496/category_13117178.html 点击跳转

· 文末祝福 ·

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	cout<<"跟着王老师一起学习信奥赛C++";
	cout<<"    成就更好的自己!       ";
	cout<<"  csp信奥赛一等奖属于你!   ";
	return 0;
}
相关推荐
光电笑映1 天前
从环境变量到进程虚拟地址空间——Linux 内存管理的底层脉络
linux·服务器·c++·c
sparEE1 天前
c++字符串和自定义字面量
开发语言·c++
蜡笔小马1 天前
03.C++设计模式-原型模式
c++·设计模式·原型模式
神仙别闹1 天前
基于QT(C++)实现线性表的建立、插入、删除、查找等基本操作
java·c++·qt
salipopl1 天前
C/C++ 中 volatile 关键字详解:原理、作用与实际应用
开发语言·c++
张赫轩(不重名)1 天前
图论3:连通性问题(复杂度均为 O(N + M) )
c++·算法·图论·拓扑学
AIminminHu1 天前
(让 C++ 程序长出大脑:从“语音遥控器”到具身智能 Agent 的进化之路)------OpenGL渲染与几何内核那点事------(二-1-(15))
开发语言·c++·agent·具身智能
君义_noip1 天前
CSP-J 2025 入门级 第一轮(初赛) 完善程序(1)
c++·算法·信息学奥赛·csp 第一轮
哭泣方源炼蛊1 天前
AtCoder Beginner Contest 456 E补题(分层图 + 有向环检测 )
c++·算法·深度优先·图论·拓扑学
Yuk丶1 天前
UE4 与 UE5:技术差异深度解析
c++·ue5·游戏引擎·ue4·游戏程序·虚幻