すべての隣接する重複したエントリは、文字列を(leetcode1047)削除 - Javaの

トピックス要件:

ストリングSは小文字、削除複製および選択に隣接する2つの同一の文字で与えられ、そしてそれらを削除された
繰り返し削除重複Sで行う、削除缶なるまで継続しない
すべての削除複製の完了最後の文字列を返した後。唯一の答え保証

例:
入力: "abbaca"
出力: "CA"

ソリューション

方法の一つ:使用スタックのアイデア

class Solution {
    public String removeDuplicates(String S) {
        if(S==null||S=="") return S;//特殊情况
        StringBuilder res=new StringBuilder();//栈
        int top=-1;//栈顶
        for(char c:S.toCharArray()){
            if(top==-1||res.charAt(top)!=c){//匹配不成功两种情况:栈为空,n不相等
                res.append(c);
                top++;
            }
            else{
                res.deleteCharAt(top);//已经匹配,删除改字符
                top--;
            }
        }
        return res.toString();
    }
}
/*
str.toCharArray()
sb.charAt()
sb.deleteCharAt()
*/

方法2:元のステップのアルゴリズム(CPP用)

class Solution {
public:
    string removeDuplicates(string S) {
        int top = 0;
        for (char ch : S) {
            if (top == 0 || S[top - 1] != ch) {
                S[top++] = ch;
            } else {
                top--;
            }
        }
        S.resize(top);
        return S;
    }
};
公開された14元の記事 ウォンの賞賛0 ビュー293

おすすめ

転載: blog.csdn.net/zmx1952822326/article/details/104118313
おすすめ