删除字符串中的所有相邻重复项(leetcode1047)——Java

题目要求:

给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们
在 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()
*/

方法二:原步算法(适用于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;
    }
};

你可能感兴趣的:(数据结构与算法)