栈+贪心,LeetCode 2434. 使用机器人打印字典序最小的字符串

一、题目

1、题目描述

给你一个字符串 s 和一个机器人,机器人当前有一个空字符串 t 。执行以下操作之一,直到 st 都变成空字符串:

  • 删除字符串 s第一个 字符,并将该字符给机器人。机器人把这个字符添加到 t 的尾部。
  • 删除字符串 t最后一个 字符,并将该字符给机器人。机器人将该字符写到纸上。

请你返回纸上能写出的字典序最小的字符串。

2、接口描述

python3
复制代码
 ​
python 复制代码
class Solution:
    def robotWithString(self, s: str) -> str:
复制代码

3、原题链接

2434. 使用机器人打印字典序最小的字符串


二、解题报告

1、思路分析

可见 字符串 t 就是一个栈,我们可以考虑在任意时刻让栈顶出栈

为了得到字典序最小结果,我们何时不得不出栈呢?

当栈顶不大于剩余字符的最小值时,我们不得不出栈

那么维护栈,并模拟即可

2、复杂度

时间复杂度: O(N)空间复杂度:O(N)

3、代码详解

python3
复制代码
 ​
python 复制代码
from string import ascii_lowercase
from collections import Counter

class Solution:
    def robotWithString(self, s: str) -> str:
        n = len(s)

        mi = 0
        res = []
        cnt = Counter(s)
        st = []
        for x in s:
            cnt[x] -= 1
            while mi < 25 and cnt[ascii_lowercase[mi]] == 0:
                mi += 1
            st.append(x)
            while st and st[-1] <= ascii_lowercase[mi]:
                res.append(st.pop())

        return ''.join(res)
复制代码
 ​
相关推荐
徐小夕@趣谈前端3 分钟前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
问好眼6 分钟前
【信息学奥赛一本通】1275:【例9.19】乘积最大
c++·算法·动态规划·信息学奥赛
Daydream.V25 分钟前
逻辑回归实例问题解决(LogisticRegression)
算法·机器学习·逻辑回归
代码无bug抓狂人25 分钟前
C语言之表达式括号匹配
c语言·开发语言·算法
不穿格子的程序员33 分钟前
从零开始写算法——普通数组篇:缺失的第一个正数
算法·leetcode·哈希算法
学历真的很重要39 分钟前
【系统架构师】第二章 操作系统知识 - 第二部分:进程管理(详解版)
学习·职场和发展·系统架构·系统架构师
Nebula_g40 分钟前
线程进阶: 无人机自动防空平台开发教程(更新)
java·开发语言·数据结构·学习·算法·无人机
rit84324991 小时前
基于MATLAB的环境障碍模型构建与蚁群算法路径规划实现
开发语言·算法·matlab
hoiii1871 小时前
MATLAB SGM(半全局匹配)算法实现
前端·算法·matlab
独自破碎E1 小时前
大整数哈希
算法·哈希算法