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

leetcodeT3170

题目:

算法分析:

单调栈 + 排序应用

考察删除*和其前面的最小字典的字符,要使得剩余的字符字典序最小,考虑删除的字符的位置: 假设删除的字符为c

1.如果删除最前面的c 整体的字符串字典序应该最大

2. 如果删除最后面的c 整体的字符串字典序最大

因此算法的整体思路:

从左到右遍历 s,用 26 个栈记录遍历过的每种字母的下标。

遇到 *,弹出最小字母栈(第一个非空栈)的栈顶。

最后把剩余下标对应的字母按顺序串起来,即为答案。

 代码:

class Solution {public String clearStars(String s) {// 建立26个栈List<Integer>[] stks = new  ArrayList[26];Arrays.setAll(stks, i -> new ArrayList<>());int n = s.length();for(int i = 0; i < n; i++) {char c = s.charAt(i);if(c != '*') {stks[c - 'a'].add(i);} else {for(List<Integer> stk: stks) {if(!stk.isEmpty()) {stk.removeLast();break;}} }}List<Integer> idx = new ArrayList<>();for(List<Integer> stk: stks) {idx.addAll(stk);}Collections.sort(idx);StringBuilder sb = new StringBuilder();for(int i: idx) {sb.append(s.charAt(i));}return sb.toString();}
}

http://www.xdnf.cn/news/12743.html

相关文章:

  • MIT 6.S081 Lab10 mmap
  • java报错ncapp生成主子表单据时报错,CarrierRuntimeException
  • 关于Qt阻断样式继承的解决办法
  • yolov12-区域注意力:让计算机“看见”更智能
  • Java 中 synchronized 和 ReentrantLock 的全面对比解析
  • ELK日志管理框架介绍
  • 在C语言中使用UUID作为AES加密密钥
  • python打卡第47天
  • 快速排序算法详解:从理论到实践的全方位指导
  • 从零开始制作小程序简单概述
  • JavaScript ES6 解构:优雅提取数据的艺术
  • 论文略读:Efficient Reasoning for LLMs through Speculative Chain-of-Thought
  • vue中的派发事件与广播事件,及广播事件应用于哪些场景和一个表单验证例子
  • Android 视图系统入门指南
  • C++常用的企业级日志库
  • 绘制饼图详细过程
  • qt使用笔记二:main.cpp详解
  • STM32的系统滴答定时器简述
  • fast-reid部署
  • LangChain面试内容整理-知识点1:LangChain架构与核心理念
  • 高并发下的缓存击穿/雪崩解决方案
  • 青少年编程与数学 01-011 系统软件简介 08 Windows操作系统
  • JavaWeb基础入门 — SpringBoot Web 案例详解
  • LBE-LEX系列工业语音播报器|AGV语音提示器|工程车音乐报警器操作使用说明
  • 亚川科技IBMS集成管理平台:构建商业综合体智慧中枢
  • LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明
  • 1-2 Linux-虚拟机(2025.6.7学习篇- win版本)
  • Android学习总结-GetX库常见问题和解决方案
  • 计算机组成与体系结构:补码数制一(Complementary Number Systems)
  • 振动力学:多自由度系统