栈+贪心,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)
复制代码
 ​
相关推荐
啊阿狸不会拉杆6 小时前
《机器学习导论》第 1 章 - 引言
人工智能·python·算法·机器学习·ai·numpy·matplotlib
轻轻唱6 小时前
2026专业PPT设计服务商推荐:TOP10深度评测与选择指南
大数据·人工智能·算法
s1hiyu6 小时前
嵌入式C++低功耗设计
开发语言·c++·算法
fanstuck6 小时前
从 0 到 1 构建企业智能体平台:openJiuwen 架构解析与智能客服工作流实战
大数据·人工智能·算法·架构·aigc
青桔柠薯片6 小时前
数据结构:单向链表和双向链表
数据结构·算法·链表
2401_841495646 小时前
【LeetCode刷题】对称二叉树
数据结构·python·算法·leetcode·二叉树··递归
飞机和胖和黄6 小时前
王道考研C语言第五周
c语言·考研·算法
市场部需要一个软件开发岗位6 小时前
一个无人机平台+算法监督平台的离线部署指南
java·python·算法·bash·无人机·持续部署
ygklwyf6 小时前
零基础薄纱树套树——高级数据结构的结合
算法·线段树·树状数组·树套树
Hello World . .7 小时前
排序算法:常用排序算法
c语言·数据结构·算法·vim·排序算法