关注
想到两种最简单的方法: 一种是多遍扫,扫到满足条件的字符串为止,复杂度>O(n); 第二种扫一遍,做好充分的标记位,一位一位根据标记位来判断需不需要输出,及时更新标记位,复杂度O(n);代码如下: 测了一下(不知道对不对😂): aabbccddeeff -> aabccdeef aabccdddfff -> aabccddf abbbbbbbbbbbba -> abba aaabbcccee -> aabcce
#include <iostream>
#include <string>
using namespace std;
int main() {
int countOfString = 0;
cin >> countOfString;
while (countOfString--) {
string inputStr, outputStr = "";
cin >> inputStr;
if (inputStr.length() == 0) {
cout << "No String!" << endl;
return 0;
}
// firstRepeat是前面有重复的,secondRepeat是当前离自己最近的有无重复
int firstRepeat = 1, secondRepeat = 0;
// 输出串中默认放入第一个
outputStr.push_back(inputStr[0]);
// 从输入串中的第一个开始扫,扫一遍即可
for (int i = 1; i < inputStr.length(); i++) {
if (inputStr[i] != inputStr[i-1]) {
// 当前字符与前一个不同情况:
if (firstRepeat == 2) {
// 如果前面的字符已经重复了两次 如:aa
if (secondRepeat == 0) {
// 如果当前的字符还没出现过,当前字符数+1,如aab
secondRepeat ++;
}else {
// 否则,当前的字符作为‘前一个’,如aabc,初始化first和second
firstRepeat = 1;
secondRepeat = 0;
}
}
}else {
// 与前一字符相同的情况:
if (secondRepeat != 0) {
// 1. aabb
secondRepeat ++;
}else {
// 2. aaa
firstRepeat ++;
}
}
// 开始根据first和second给输出赋值
if (firstRepeat == 3) {
// aaa情况
firstRepeat --;
}else if (secondRepeat == 2) {
// aabb情况
firstRepeat = --secondRepeat;
secondRepeat = 0;
}else {
// 满足上述两种情况不输出,否则直接输出
outputStr.push_back(inputStr[i]);
}
}
// 输出
for (int i = 0; i < outputStr.length(); i++) {
cout << outputStr[i];
}
cout << endl;
}
return 0;
}
查看原帖
点赞 3
相关推荐

点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 从顶到拉给所有面过的公司评分 #
23526次浏览 192人参与
# 机械人春招想让哪家公司来捞你? #
357840次浏览 3109人参与
# 为了求职,我做过的疯狂伪装 #
13796次浏览 277人参与
# 校招笔试 #
1406次浏览 34人参与
# 职场破冰,你们都聊什么? #
8077次浏览 79人参与
# 晒晒你的中秋福利 #
15831次浏览 120人参与
# 大家实习每天都在干啥 #
89496次浏览 518人参与
# 你的公司给实习生发中秋礼物吗 #
2504次浏览 31人参与
# 机械笔面试考察这些知识点 #
10903次浏览 96人参与
# bilibili求职进展汇总 #
91549次浏览 820人参与
# 工作压力大怎么缓解 #
105664次浏览 1053人参与
# 秋招OC许愿 #
347642次浏览 2531人参与
# 广联达求职进展汇总 #
11466次浏览 50人参与
# 机械人怎么评价今年的华为 #
209427次浏览 1525人参与
# 宣讲会你有哪些意向不到的收获 #
1950次浏览 23人参与
# 聊聊这家公司值得去吗 #
561252次浏览 3717人参与
# 你面试被问到过哪些不会的问题? #
23640次浏览 848人参与
# 百度秋招提前批进度 #
151249次浏览 1772人参与
# 电网笔面经互助 #
47188次浏览 431人参与
# 秋招的嫡长offer #
33245次浏览 299人参与