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

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

问题描述

给定一个字符串 s,需要重复地删除其中所有相邻的重复项,直到没有任何相邻字符是重复的。最后返回处理后的字符串。

示例

  • 示例 1:
  • 输入: abbaca
  • 输出: ca
  • 解释: 先删除 bb(得到 aaca),然后删除 aa(得到 ca)。


示例 2:

  • 输入: abbbabaa
  • 输出: abba
  • 解释: 删除可能有不同的顺序,比如先删除第一个 bb 再删除第二个 bb 得到 abaa,然后再删除 aa 得到 ab
class Solution {
    public String removeDuplicates(String S) {
        StringBuffer stack = new StringBuffer();
        int top = -1;
        for (int i = 0; i < S.length(); ++i) {
            char ch = S.charAt(i);
            if (top >= 0 && stack.charAt(top) == ch) {
                stack.deleteCharAt(top);
                --top;
            } else {
                stack.append(ch);
                ++top;
            }
        }
        return stack.toString();
    }
}
  • StringBuffer 作为栈
  • StringBuffer 用于存储字符,模拟栈的行为。
  • 变量 top 用来追踪栈顶位置。
  • 遍历字符串 S
  • 对于每个字符 ch,检查与栈顶字符是否相同。
  • 栈操作
  • 如果栈不为空(top >= 0)且栈顶字符与当前字符相同,则删除栈顶字符,并更新栈顶位置 top
  • 否则,将当前字符添加到 stack 中,并更新栈顶位置 top
  • 返回结果
  • StringBuffer 转换为字符串并返回。


优点

  • 空间效率:直接使用 StringBuffer 而不是标准栈结构,减少了空间开销。
  • 时间效率:由于 StringBuffer 的内部实现优化,这种方法比标准栈操作更快。
  • 简洁性:代码简洁明了,易于理解。


复杂度分析

  • 时间复杂度:O(n),其中 n 是字符串长度。每个字符被处理一次。
  • 空间复杂度:O(n),最坏情况下,StringBuffer 中可能需要存储所有字符。

可能有疑问


为什么 如果栈不为空就是top >= 0


变量 top 被用来追踪 StringBuffer(在这里充当栈的角色)的栈顶位置。这里的逻辑是:


当 stack(StringBuffer 实例)为空时,意味着没有任何元素被添加进去。在这种情况下,top 的值为 -1。这是因为在空的 StringBuffer 中,没有任何字符的索引可以是 0 或更大的数(在Java中,索引通常是从 0 开始的)。因此,-1 被用作表示“栈空”或“没有元素”的标记。


当向 stack 中添加第一个元素时,top 的值从 -1 变为 0,表示现在有一个元素在 stack 中,且这个元素位于索引 0 的位置(也就是栈顶)。


因此,如果 top 的值大于或等于 0,意味着 stack 中至少有一个元素,即 stack 不为空。相反,如果 top 的值仍然是 -1,则意味着 stack 为空。


top >= 0 的条件用来检查 stack 是否不为空,即是否有元素可以进行比较和可能的删除操作。这种使用一个额外的变量来追踪栈顶位置的方法是一种常见的编程技巧,用于在不使用标准栈数据结构的情况下模拟栈的行为。


相关文章
|
2月前
|
Java C++ Python
leetcode-1047:删除字符串中的所有相邻重复项
leetcode-1047:删除字符串中的所有相邻重复项
30 0
|
9月前
|
存储 算法 前端开发
前端算法-删除字符串中的所有相邻重复项
前端算法-删除字符串中的所有相邻重复项
|
2月前
leetcode代码记录(删除字符串中的所有相邻重复项
leetcode代码记录(删除字符串中的所有相邻重复项
18 0
|
9月前
【Leetcode -844.比较含退格的字符串 -1047.删除字符串中的所有相邻重复项】
【Leetcode -844.比较含退格的字符串 -1047.删除字符串中的所有相邻重复项】
36 0
|
10月前
⌈力扣⌋删除字符串中的所有相邻重复项
⌈力扣⌋删除字符串中的所有相邻重复项
37 0
|
11月前
|
存储 算法
数组算法:倒置,查找,插入,删除
数组算法:倒置,查找,插入,删除
71 0
每日一题——删除字符串中的所有相邻重复项
每日一题——删除字符串中的所有相邻重复项
|
算法
LeetCode每日1题--删除字符串中的所有相邻重复项
LeetCode每日1题--删除字符串中的所有相邻重复项
54 0
|
算法
LeetCode:1047. 删除字符串中的所有相邻重复项——栈
题目描述:给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们。 在 S 上反复执行重复项删除操作,直到无法继续删除。 在完成所有重复项删除操作后返回最终的字符串。答案保证唯一
leetcode 1047 删除字符串中的所有相邻重复
leetcode 1047 删除字符串中的所有相邻重复
57 0
leetcode 1047 删除字符串中的所有相邻重复

热门文章

最新文章

  • 1
    流量控制系统,用正则表达式提取汉字
    25
  • 2
    Redis09-----List类型,有序,元素可以重复,插入和删除快,查询速度一般,一般保存一些有顺序的数据,如朋友圈点赞列表,评论列表等,LPUSH user 1 2 3可以一个一个推
    26
  • 3
    Redis08命令-Hash类型,也叫散列,其中value是一个无序字典,类似于java的HashMap结构,Hash结构可以将对象中的每个字段独立存储,可以针对每字段做CRUD
    26
  • 4
    Redis07命令-String类型字符串,不管是哪种格式,底层都是字节数组形式存储的,最大空间不超过512m,SET添加,MSET批量添加,INCRBY age 2可以,MSET,INCRSETEX
    27
  • 5
    S外部函数可以访问函数内部的变量的闭包-闭包最简单的用不了,闭包是内层函数+外层函数的变量,简称为函数套函数,外部函数可以访问函数内部的变量,存在函数套函数
    24
  • 6
    Redis06-Redis常用的命令,模糊的搜索查询往往会对服务器产生很大的压力,MSET k1 v1 k2 v2 k3 v3 添加,DEL是删除的意思,EXISTS age 可以用来查询是否有存在1
    30
  • 7
    Redis05数据结构介绍,数据结构介绍,官方网站中看到
    22
  • 8
    JS字符串数据类型转换,字符串如何转成变量,+号只要有一个是字符串,就会把另外一个转成字符串,- * / 都会把数据转成数字类型,数字型控制台是蓝色,字符型控制台是黑色,
    20
  • 9
    JS数组操作---删除,arr.pop()方法从数组中删除最后一个元素,并返回该元素的值,arr.shift() 删除第一个值,arr.splice()方法,删除指定元素,arr.splice,从第一
    20
  • 10
    定义好变量,${age}模版字符串,对象可以放null,检验数据类型console.log(typeof str)
    19