LeetCode #1047 Remove All Adjacent Duplicates In String 刪除字符串中的所有相鄰重復項

1047 Remove All Adjacent Duplicates In String 刪除字符串中的所有相鄰重復項

Description:
Given a string S of lowercase letters, a duplicate removal consists of choosing two adjacent and equal letters, and removing them.

We repeatedly make duplicate removals on S until we no longer can.

Return the final string after all such duplicate removals have been made. It is guaranteed the answer is unique.

Example:

Example 1:

Input: "abbaca"
Output: "ca"
Explanation:
For example, in "abbaca" we could remove "bb" since the letters are adjacent and equal, and this is the only possible move. The result of this move is that the string is "aaca", of which only "aa" is possible, so the final string is "ca".

Note:

1 <= S.length <= 20000
S consists only of English lowercase letters.

題目描述:
給出由小寫字母組成的字符串 S笆载,重復項刪除操作會選擇兩個相鄰且相同的字母,并刪除它們涯呻。

在 S 上反復執(zhí)行重復項刪除操作凉驻,直到無法繼續(xù)刪除。

在完成所有重復項刪除操作后返回最終的字符串复罐。答案保證唯一涝登。

示例 :

輸入:"abbaca"
輸出:"ca"
解釋:
例如,在 "abbaca" 中效诅,我們可以刪除 "bb" 由于兩字母相鄰且相同胀滚,這是此時唯一可以執(zhí)行刪除操作的重復項。之后我們得到字符串 "aaca"乱投,其中又只有 "aa" 可以執(zhí)行重復項刪除操作咽笼,所以最后的字符串為 "ca"。

提示:

1 <= S.length <= 20000
S 僅由小寫英文字母組成戚炫。

思路:

參考LeetCode #20 Valid Parentheses 有效的括號
將字符壓入棧, 再比較, 相同的丟棄
時間復雜度O(n), 空間復雜度O(1)

代碼:
C++:

class Solution 
{
public:
    string removeDuplicates(string S) 
    {
        int top = 0;
        for (auto c : S)
        {
            if (!top or S[top - 1] != c) S[top++] = c;
            else top--;
        }
        S.resize(top);
        return S;
    }
};

Java:

class Solution {
    public String removeDuplicates(String S) {
        StringBuilder result = new StringBuilder();
        for (int i = 0; i < S.length(); ++i) {
            if (result.length() == 0) result.append(S.charAt(i));
            else if (result.charAt(result.length() - 1) == S.charAt(i)) result.setLength(result.length() - 1);
            else result.append(S.charAt(i));
        }
        return  result.toString();
    }
}

Python:

class Solution:
    def removeDuplicates(self, S: str) -> str:
        s = []
        for c in S:
            if s and s[-1] == c:
                s.pop()
            else:
                s.append(c)
        return ''.join(s)
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末剑刑,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子双肤,更是在濱河造成了極大的恐慌施掏,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件茅糜,死亡現(xiàn)場離奇詭異其监,居然都是意外死亡,警方通過查閱死者的電腦和手機限匣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來毁菱,“玉大人米死,你說我怎么就攤上這事≈樱” “怎么了峦筒?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長窗慎。 經常有香客問我物喷,道長卤材,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任峦失,我火速辦了婚禮扇丛,結果婚禮上,老公的妹妹穿的比我還像新娘尉辑。我一直安慰自己帆精,他們只是感情好,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布隧魄。 她就那樣靜靜地躺著卓练,像睡著了一般。 火紅的嫁衣襯著肌膚如雪购啄。 梳的紋絲不亂的頭發(fā)上襟企,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天,我揣著相機與錄音狮含,去河邊找鬼顽悼。 笑死,一個胖子當著我的面吹牛辉川,可吹牛的內容都是我干的表蝙。 我是一名探鬼主播,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼乓旗,長吁一口氣:“原來是場噩夢啊……” “哼府蛇!你這毒婦竟也來了?” 一聲冷哼從身側響起屿愚,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤汇跨,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后妆距,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體穷遂,經...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年娱据,在試婚紗的時候發(fā)現(xiàn)自己被綠了蚪黑。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡中剩,死狀恐怖忌穿,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情结啼,我是刑警寧澤掠剑,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站郊愧,受9級特大地震影響朴译,放射性物質發(fā)生泄漏井佑。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一眠寿、第九天 我趴在偏房一處隱蔽的房頂上張望躬翁。 院中可真熱鬧,春花似錦澜公、人聲如沸姆另。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽迹辐。三九已至,卻和暖如春甚侣,著一層夾襖步出監(jiān)牢的瞬間明吩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工殷费, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留印荔,地道東北人。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓详羡,卻偏偏與公主長得像仍律,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子实柠,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內容