C++删除相邻相同字母

/*
给出一个由小写字母组成的字符串,找出两个相邻且相同的字母,并删除它们。
在该字符串上反复执行上述操作,直到无法继续删除。
在完成所有重复项删除后返回最终的字符串。
输入描述:小写字母组成的字符串
输出描述:删除后的字符串
样例输入:dbbdut
样例输出:ut
*/

#include <iostream>
#include <stack>
using namespace std;

string removeDuplicates(string s) {
    stack<char> st;

    for (char c : s) {
        if (!st.empty() && st.top() == c) {
            st.pop();
        }
        else {
            st.push(c);
        }
    }

    string result = "";
    while (!st.empty()) {
        result = st.top() + result;
        st.pop();
    }

    return result;
}

int main() {
    string input;
    cout << "请输入小写字母组成的字符串: ";
    cin >> input;

    string result = removeDuplicates(input);

    cout << "删除后的字符串: " << result << endl;

    return 0;
}

全部评论

相关推荐

10-17 23:18
已编辑
西北农林科技大学 Web前端
独行m:给25可以试试,但他只能给12,那就是纯纯的事精
秋招,不懂就问
点赞 评论 收藏
分享
10-28 17:30
已编辑
华东交通大学 Java
iori2333:这太正常了 我字节面了四五轮 没有一次是在官网投递 都是hr主动捞
秋招笔试记录
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务