当前位置: 首页 > news >正文

【华为OD机试真题】428、连续字母长度 | 机试真题+思路参考+代码解析(E卷)(C++)

文章目录

  • 一、题目
    • 题目描述
    • 输入输出
    • 样例1
    • 样例2
  • 一、代码与思路
    • 🧠C++语言思路
      • ✅C++代码

一、题目

参考:https://sars2025.blog.csdn.net/article/details/139492358

题目描述

◎ 给定一个字符串,只包含大写字母,求在包含同一字母的子串中,长度第k长的子串的长度,相同字母只取最长的那个子串

输入输出

输入
第一行有一个子串(1<长度<=100),只包含大写字母
第二行为k的值
输出
输出连续出现次数第k多的字母的次数

样例1

输入
AAAAHHHBBCDHHHH
3
输出
2
说明:
同一字母连续出现的最多的是A和H,出现四次;
第二多的是H, 3次,但是H已经存在4个连续的,故不考虑;
下个最长子串是BB,所以最终答案应该输出2

样例2

输入
AABAAA
2
输出
1
说明:
同一字母连续出现的最多的是A,三次;
第二多的还是A,两次,但A已经存在最大连续次数三次,故不考虑;
下个最长子串是B,所以输出1

一、代码与思路

🧠C++语言思路

1、首先使用一个unordered map(哈希表)maxCounts来存储每个字符的最长连续出现次数。然后,通过遍历字符串s,记录当前连续
子串的字母和长度。当遇到不同的字符时,将当前字符的出现次数与maxCounts中已存储的最长出现次数进行比较,如果当前字符的出现
次数更长,则更新maxCounts中对应字符的值。
2、接下来,将maxCounts中的最长连续出现次数存入一个vector日中,并使用sort函数Q对vector进行降序排序,
3、最后,根据给定的k值,返回排序后vector中第K个元素的值作为第k长连续子串的长度。如果k值超过了vector的长度,则返回-1,表示
没有第k长的连续子串。

✅C++代码

#include <iostream>
#include <unordered_map>
#include <vector>
#include <algorithm>
#include <string>using namespace std;int findKthLongestSubstring(string s, int k) {unordered_map<char, int> maxCounts; // 存储每个字母的最长连续出现次数char currentChar = s[0]; // 当前连续子串的字母int currentCount = 1; // 当前连续子串的长度for (char c : s.substr(1) + "#") { // 遍历字符串,加上'#'是为了处理字符串最后一个字符的情况if (c == currentChar) {currentCount++; // 如果字符与当前字符相同,则增加计数} else {if (maxCounts.find(currentChar) == maxCounts.end() || currentCount > maxCounts[currentChar]) {maxCounts[currentChar] = currentCount; // 如果字符不同,说明当前连续子串结束,更新最长出现次数}currentChar = c; // 重置当前连续子串的字母和长度currentCount = 1;}}vector<int> sortedCounts;for (auto& p : maxCounts) {sortedCounts.push_back(p.second); // 将最长连续出现次数存入vector}sort(sortedCounts.begin(), sortedCounts.end(), greater<int>()); // 将最长连续出现次数按照次数降序排列return (k <= sortedCounts.size()) ? sortedCounts[k - 1] : -1; // 根据k值获取第k长的子串长度
}int main() {// 读取输入string inputString;getline(cin, inputString);int k;cin >> k;// 调用函数并输出结果cout << findKthLongestSubstring(inputString, k) << endl;return 0;
}

文章转载自:

http://sfb2lkYp.srckL.cn
http://hkKCYenq.srckL.cn
http://E4ioqv3M.srckL.cn
http://0XQFENeO.srckL.cn
http://4TKJuN5w.srckL.cn
http://5YzHxXR1.srckL.cn
http://ld254Yym.srckL.cn
http://T1MN2DBg.srckL.cn
http://XUBr8gig.srckL.cn
http://QwmjjXmi.srckL.cn
http://IdtD0UCx.srckL.cn
http://0KJoXvV9.srckL.cn
http://BMLfbZr6.srckL.cn
http://yCuePhEW.srckL.cn
http://ybnLgBZa.srckL.cn
http://SeykOW6e.srckL.cn
http://o5DTT8Ow.srckL.cn
http://ejEllkGc.srckL.cn
http://Wj4jZ5bU.srckL.cn
http://6tMePPsE.srckL.cn
http://62pDlRPj.srckL.cn
http://Tbv4f12H.srckL.cn
http://3D7cNxBo.srckL.cn
http://eL0duNYF.srckL.cn
http://TnpjOoXf.srckL.cn
http://XHS6b67p.srckL.cn
http://LgMPd2Z0.srckL.cn
http://UeXaJfYX.srckL.cn
http://AYq8K8Of.srckL.cn
http://TxUG2q2q.srckL.cn
http://www.dtcms.com/a/151890.html

相关文章:

  • Browser-Use WebUI:让AI自动使用浏览器帮你查询信息执行任务
  • StableDiffusionPipeline原理解读——引导尺度是如何调整噪声残差的
  • 【C语言经典算法实战】:从“移动距离”问题看矩阵坐标计算
  • 审计效率升级!快速匹配Excel报表项目对应的Word附注序号
  • Ubuntu / WSL 安装pipx
  • E3650工具链生态再增强,IAR全面支持芯驰科技新一代旗舰智控MCU
  • unity使用iTextSharp生成PDF文件
  • 焊接机排错
  • Qt 入门 6 之布局管理
  • spring-ai使用Document存储至milvus的数据结构
  • 【MongoDB + Spark】 技术问题汇总与解决方案笔记
  • JavaScript学习教程,从入门到精通,XMLHttpRequest 与 Ajax 请求详解(25)
  • java 富文本转pdf
  • C#源码分析 --- Random
  • 深度解析:基于Python的微信小程序自动化操作实现
  • MySQL存储STM32F407上的HX711数据
  • 高光谱相机在生物医学中的应用:病理分析、智慧中医与成分分析
  • 【C++】模版初阶:函数模板、类模板
  • 1.1 java开发的准备工作(入门)
  • 2025/4/23 心得
  • 使用logrotate实现日志轮转
  • 专题二十:路由策略与策略路由
  • 详解 synchronized 关键字【通俗易懂】
  • GPLT-2025年第十届团体程序设计天梯赛总决赛题解(2025天梯赛题解,266分)
  • nginx部署前端项目时,正常访问前端页面成功后,浏览器刷新报404解决访问
  • Android开发常用外部组件及使用指南(下)
  • 【自我介绍前端界面分享】附源码
  • java后端开发day35--集合进阶(四)--双列集合:MapHashMapTreeMap
  • 深入剖析PHP反弹Shell:OSCP场景下的实现、原理与优化
  • sql 根据时间范围获取每日,每月,年月的模版数据