文章目录
一、题目
题目描述
◎ 给定一个字符串,只包含大写字母,求在包含同一字母的子串中,长度第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;
}