【华为OD机试真题】428、连续字母长度 | 机试真题+思路参考+代码解析(E卷)(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++代码

cpp 复制代码
#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;
}
相关推荐
si莉亚1 分钟前
ROS2安装EVO工具包
linux·开发语言·c++·开源
清心歌9 分钟前
CopyOnWriteArrayList 实现原理
java·开发语言
智者知已应修善业19 分钟前
【51单片机单按键切换广告屏】2023-5-17
c++·经验分享·笔记·算法·51单片机
良木生香32 分钟前
【C++初阶】C++入门相关知识(2):输入输出 & 缺省参数 & 函数重载
开发语言·c++
小此方33 分钟前
Re:从零开始的 C++ 进阶篇(三)彻底搞懂 C++ 多态:虚函数、虚表与动态绑定的底层原理
c++
忘梓.33 分钟前
墨色规则与血色节点:C++红黑树设计与实现探秘
java·开发语言·c++
hhh3u3u3u34 分钟前
Visual C++ 6.0中文版安装包下载教程及win11安装教程
java·c语言·开发语言·c++·python·c#·vc-1
凤年徐36 分钟前
C++手撕红黑树:从0到200行,拿下STL map底层核心
c++·后端·算法
星河耀银海37 分钟前
C++ 模板进阶:特化、萃取与可变参数模板
java·开发语言·c++
cccccc语言我来了41 分钟前
【C++---unordered_set/map底层封装】个不拘一格的集合。它不似有序集合那般循规蹈矩,而是以一种洒脱不羁的方式,将元素们随意地散落其中。每一个元素都是独一无二的。
开发语言·c++·哈希算法