删除字符串中的所有相邻重复项

题目

给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们。
在 S 上反复执行重复项删除操作,直到无法继续删除。
在完成所有重复项删除操作后返回最终的字符串。答案保证唯一。

示例

输入:”abbaca”
输出:”ca”
解释:
例如,在 “abbaca” 中,我们可以删除 “bb” 由于两字母相邻且相同,这是此时唯一可以执行删除操作的重复项。之后我们得到字符串 “aaca”,其中又只有 “aa” 可以执行重复项删除操作,所以最后的字符串为 “ca”。

思考

自己思考的代码是利用多次循环,先删去相邻相同的元素,再进行循环判断有没有相同的。
看了题解,改良代码,利用栈,一个个压进栈里进行比较,与下一个相同就删除,是线性操作的

代码

class Solution {
    public String removeDuplicates(String S) {
        while (true){
            StringBuilder a = new StringBuilder();
            int count = 0;
            for (int i = 0; i < S.length(); i++) {
                if (i < S.length() - 1 && S.charAt(i) == S.charAt(i + 1)) {
                    i++;
                    count++;
                } else {
                    a.append(S.charAt(i));
                }
            }
            if (count == 0)
                break;
            S = a.toString();
        }
        return S.toString();
    }
}

改良后
class Solution {
    public String removeDuplicates(String S) {
        StringBuilder a = new StringBuilder();
        int aLength = 0;
        for (char c : S.toCharArray()) {
            if (aLength != 0 && c == a.charAt(aLength - 1)) {
                a.deleteCharAt(aLength-- - 1);
            } else {
                a.append(c);
                aLength++;
            }
        }
        return a.toString();
    }
}
暂无评论

发送评论 编辑评论


|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇