力扣-从字符串中移除星号

思路分析

  1. 遍历字符串每个字符:
    • 遇到非星号字符:压入栈中(暂存待保留的字符);
    • 遇到星号:弹出栈顶元素(即左侧最近的非星号字符),同时星号自身不压栈(等价于删除星号);
  2. 拼接栈内剩余字符:栈中保留的就是删除所有星号后的结果,按顺序拼接即可。

代码实现

java 复制代码
/**
* 借助栈实现
**/
public String removeStars(String str) {
   // 遍历字符串,做入栈操作,如果为 * 切栈不为空,则做出栈操作
   Deque<Character> stack = new ArrayDeque<>();
   for (int i = 0; i < str.length(); i++) {
       char charAt = str.charAt(i);
       // 若不是 * ,则入栈
       if (charAt != '*'){
           stack.push(charAt);
       } else{
           // 如果是 * ,则出栈
           if (!stack.isEmpty()){
               stack.pop();
           }
       }
   }
   StringBuilder sb = new StringBuilder();
   while (!stack.isEmpty()){
       sb.append(stack.pop());
   }
   return sb.reverse().toString();
}

/**

  • 使用字符串模拟栈
    **/
java 复制代码
public String removeStars2(String str) {
    StringBuilder sb = new StringBuilder();
    for (int i = 0; i < str.length(); i++) {
        char charAt = str.charAt(i);
        // 如果不是*,则入栈
        if (charAt != '*'){
            sb.append(charAt);
        } else{
            if (sb.length() > 0){
                sb.deleteCharAt(sb.length() - 1);
            }
        }
    }
    return sb.toString();
}

复杂度分析

  • 时间复杂度:O(n) → 遍历字符串 n 个字符(每个字符仅处理 1 次),拼接结果也是 O (n);
  • 空间复杂度:O(n) → 最坏情况无星号,栈 / StringBuilder 存储所有 n 个字符。
相关推荐
一 乐5 分钟前
家政服务管理系统|基于springboot + vue家政服务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·家政服务管理系统
Matrix_119 分钟前
手机里的计算摄影:广角形变校正算法
人工智能·算法·智能手机·计算摄影
WBluuue14 分钟前
数据结构与算法:有序表(二):跳表
数据结构·c++·算法·skiplist
碳基硅坊1 小时前
Spring AI:把大模型接进 Spring 应用
java·人工智能·spring ai
黄毛火烧雪下1 小时前
Java 核心知识点总结(一)
java·开发语言
x138702859571 小时前
c语言中srtlen(指针使用计算字符长度)、传值和传址调用
c语言·开发语言·算法·visual studio
海兰2 小时前
【实用程序】电商销售分析仪表盘 — 从零搭建一个AI参与的全栈数据洞察系统
人工智能·学习·算法
技术小结-李爽2 小时前
【工具】Maven的下载、安装、使用
java·maven
极创信息2 小时前
Linux挖矿病毒深度清理实战教程,从进程隐藏、Rootkit驻留到彻底根除
java·大数据·linux·运维·安全·tomcat·健康医疗
努力成为AK大王2 小时前
并发编程的核心挑战、优化方案与核心知识点总结
java·开发语言·数据库