【栈】【快慢双指针】Leetcode 1047 删除字符串中的所有相邻重复项

【栈】【双指针】Leetcode 1047 删除字符串中的所有相邻重复项

    • [解法1 利用栈](#解法1 利用栈)
    • [解法2 双指针(快慢指针)](#解法2 双指针(快慢指针))

---------------🎈🎈题目链接🎈🎈-------------------

解法1 利用栈

如果栈顶元素和当前的字符相同,就弹出栈顶元素

如果不相同就把当前字符push进栈中

最终输出栈中剩下的元素为字符串形式

时间复杂度O(N)
空间复杂度O(N)

java 复制代码
class Solution {
    public String removeDuplicates(String s) {
        Stack<Character> mystack = new Stack<>();
        for(int i = 0; i<s.length(); i++){
            char mychar = s.charAt(i);
            if(!mystack.isEmpty() && mystack.peek()== mychar){  
                mystack.pop();
                continue;
            }
            mystack.push(mychar);
        }
        String result = new String();
        result = "";
        while(!mystack.isEmpty()){
            result = mystack.pop() + result;
        }

        return result;

    }
}  

解法2 双指针(快慢指针)

首先将字符串转化为字符串数组char chararray = s.toCharArray();

使用fast和slow两个指针,当遇到slow和fast指针指向的字符相同时,则slow--,fast++

其余时候只需要ch[slow] = ch[fast] 覆盖操作即可,之后slow++, fast++

最后将索引0到slow的字符串数组转化为字符串String resultString = new String(chararray, 0, slow)

时间复杂度O(N)
空间复杂度O(1)

java 复制代码
class Solution {
    public String removeDuplicates(String s) {
        char[] ch = s.toCharArray();
        int fast = 0;
        int slow = 0;
        while(fast < s.length()){
            ch[slow] = ch[fast];
            if(slow > 0 &&  ch[slow] == ch[slow-1]){
                slow--;
                fast++;
                continue;
            }
            slow++;
            fast++;
            
        }
        String result  = new String(ch,0,slow);
        return result;

    }
}
相关推荐
Seven9716 分钟前
剑指offer-3、从尾到头打印链表
java
江小北29 分钟前
今天去面试了,遇到一个面试题,spring单例bean是线程安全的吗?
java·后端·spring
天天摸鱼的java工程师30 分钟前
设计一个多租户 SaaS 系统,如何实现租户数据隔离(数据库级别 / 表级别)与资源配额控制?
java·后端·面试
物联网嵌入式小冉学长35 分钟前
10.C S编程错误分析
c语言·stm32·单片机·算法·嵌入式
看她闹~1 小时前
javacv添加字幕 剧中显示
java·javacv·字幕
风象南2 小时前
Spring Boot 的 3 种动态 Bean 注入技巧
java·spring boot·后端
移动开发者1号2 小时前
Kotlinx序列化多平台兼容性详解
android·java·kotlin
东阳马生架构11 小时前
商品中心—6.商品考核系统的技术文档
java
晴空月明12 小时前
Java 内存模型与 Happens-Before 关系深度解析
java
皮皮林55115 小时前
SpringBoot 加载外部 Jar,实现功能按需扩展!
java·spring boot