码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 力扣1047-删除字符串中的所有相邻重复项)——栈


    题目描述

    给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们。

    在 S 上反复执行重复项删除操作,直到无法继续删除。

    在完成所有重复项删除操作后返回最终的字符串。答案保证唯一。

    解题思路

    这道题目和括号有效性判断是同样的思路:

    力扣20-有效的括号——栈实现力扣20-有效的括号——栈实现https://blog.csdn.net/weixin_44564247/article/details/126027209下面的动态图比较清晰,来自卡哥的代码随想录

    •  变量字符串s;
    • 如果deque为空或者栈顶的元素与当前遍历元素不一致,则将这个元素ch入栈;
    • 否则,该元素将弹出栈(也就是栈顶元素与当前遍历元素ch一致);
    • 最后,栈中将保存不重复的字符串,但是出栈需要做一次反转。

    利用Deque解决

    java中可以使用两种方式创造栈。

    (1)ArrayDeque arr = new ArrayDeque<>();

    (2)Deque arr = new LinkedList<>();

    注:除了删除元素这一点外,ArrayDeque会比LinkedList会快一点。

    利用StringBuffer解决

    String是字符串常量,是不可以更改的;

    但是StringBuffer是字符串变量,需要建立索引变量top指向最后一个元素;

    最后只需要将StringBuffer转为String即可。

    String 与 StringBuffer 之间的转换为:

    String、StringBuffer 的转换_(●—●)大白的博客-CSDN博客_string转换stringbufferStringBuffer和String相互转换https://blog.csdn.net/weixin_43731094/article/details/125090288

    输入输出示例

    代码

    利用Deque解决

    1. class Solution {
    2. public String removeDuplicates(String s) {
    3. int len = s.length();
    4. Deque deque = new LinkedList<>();
    5. char ch;
    6. for(int i = 0; i < len; i++){
    7. ch = s.charAt(i);
    8. if(deque.isEmpty() || deque.peek() != ch){
    9. deque.push(ch);
    10. }else{
    11. deque.pop();
    12. }
    13. }
    14. String st = "";
    15. while(!deque.isEmpty()){
    16. st = deque.pop() + st;
    17. }
    18. return st;
    19. }
    20. }

    利用StringBuffer解决

    1. class Solution{
    2. public String removeDuplicates(String s){
    3. int len = s.length();
    4. StringBuffer str = new StringBuffer();
    5. char ch;
    6. int top = -1;
    7. for(int i = 0; i < len; i++){
    8. ch = s.charAt(i);
    9. if(top >= 0 && ch == str.charAt(top)){
    10. str.deleteCharAt(top);
    11. top--;
    12. }else{
    13. str.append(ch);
    14. top++;
    15. }
    16. }
    17. return str.toString();
    18. }
    19. }

  • 相关阅读:
    Mybatis-Plus 之 Wrapper
    【数据结构】双向链表
    振弦采集模块UART 通讯协议
    PWM驱动舵机
    hive拼接字符串concat函数的用法
    如何安装 StoneDB 2.0 企业版? | StoneDB 使用教程 #2
    基于深度学习的端到端自动驾驶的最新进展:调研综述
    中国传统美食网页HTML代码 学生网页课程设计期末作业下载 美食大学生网页设计制作成品下载 DW餐饮美食网页作业代码下载
    基于微信小程序的党员之家服务系统设计与实现-计算机毕业设计源码和lw文档
    18【命令设计模式】
  • 原文地址:https://blog.csdn.net/weixin_44564247/article/details/126035798
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号