当前位置: 首页 > article >正文

数据结构与算法之栈: LeetCode 1047. 删除字符串中的所有相邻重复项 (Ts版)

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

  • https://leetcode.cn/problems/remove-all-adjacent-duplicates-in-string/

描述

  • 给出由小写字母组成的字符串 s,重复项删除操作会选择两个相邻且相同的字母,并删除它们
  • 在 s 上反复执行重复项删除操作,直到无法继续删除
  • 在完成所有重复项删除操作后返回最终的字符串。答案保证唯一

示例

输入:"abbaca"
输出:"ca"

解释:例如,在 “abbaca” 中,我们可以删除 “bb” 由于两字母相邻且相同,这是此时唯一可以执行删除操作的重复项。之后我们得到字符串 “aaca”,其中又只有 “aa” 可以执行重复项删除操作,所以最后的字符串为 “ca”

提示

  • 1 <= s.length <= 1 0 5 10^5 105
  • s 仅由小写英文字母组成

Typescript 版算法实现


1 ) 方案1: 栈

function removeDuplicates(s: string): string {
    const stk = [];
    for (const ch of s) {
        if (stk.length && stk[stk.length - 1] === ch) {
            stk.pop();
        } else {
            stk.push(ch);
        }
    }
    return stk.join('');
};

2 ) 方案2:栈优化

function removeDuplicates(s: string): string {
    const stack = []
    for (const x of s) {
        let len = stack.length
        if (len && stack[len - 1] == x) {
            stack.pop()
            continue
        }
        stack.push(x)
    }
    return stack.join("")
};

http://www.kler.cn/a/504613.html

相关文章:

  • JVM 核心知识点总结
  • springboot使用阿里oss实现文件上传
  • 如何优化Elasticsearch大文档查询?
  • haproxy+httpd网站架构,实现负载均衡实验笔记
  • 【centos】校时服务创建
  • C 语言标准库函数——strtol函数
  • C#轻松实现ModbusTCP服务器接口
  • 高性能、低成本立体声音频模数转换器—— GC1808,支持掉电和时钟检测低功耗模式
  • Go语言的数据竞争 (Data Race) 和 竞态条件 (Race Condition)
  • Centos 离线安装杀毒软件
  • 基于禁忌搜索算法的TSP问题最优路径搜索matlab仿真
  • HarmonyOS鸿蒙-@State@Prop装饰器限制条件
  • kalilinux - 目录扫描之dirsearch
  • Autodl转发端口,在本地机器上运行Autodl服务器中的ipynb文件
  • linux通过web向mac远程传输字符串,mac收到后在终端中直接打印。
  • 微信小程序wx.showToast在真机显示时时间设置无效,显示时间很短问题
  • 传统架构下应用部署
  • 匿名管道通信
  • 深入浅出 Vue.js 渐进式加载图片组件开发
  • CSS 元素的显示模式(块元素,行内元素,行内块元素)