去除重复字母——贪心+单调栈

给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。需保证 返回结果的字典序最小(要求不能打乱其他字符的相对位置)。

示例 1:

复制代码
输入:s = "bcabc"
输出:"abc"

示例 2:

复制代码
输入:s = "cbacdcbc"

输出:"acdb"

提示:

  • 1 <= s.length <= 104
  • s 由小写英文字母组成

思路:如果后面还有,就保持单调递增栈;后面这个字母没了,就不能弹出来。

python 复制代码
from collections import defaultdict


class Solution:
    def removeDuplicateLetters(self, s: str) -> str:
        stack=[]
        charactersDict=defaultdict(int)
        visited=[False]*26
        for char in s:
            charactersDict[char]+=1

        for char in s:
            if not visited[ord(char)-ord('a')]:
                while stack and charactersDict[stack[-1]]>0 and ord(char)<ord(stack[-1]):
                    visited[ord(stack[-1])-ord('a')]=False
                    stack.pop()
                visited[ord(char)-ord('a')]=True
                stack.append(char)
                charactersDict[char]-=1
        return ''.join(stack)

第一版自己的写法:

贪心,找到当前能找到的最小值,设定每次向右寻找的极限,到达这个极限的时候,必须选出来一个(因为之后就没有这个数了,必须选出来了,在之后出现更小的也没意义)

python 复制代码
class Solution:
    def removeDuplicateLetters(self, s: str) -> str:
        lst=list(s)
        characters = [[] for _ in range(26)]
        for i in  range(len(lst)):
            characters[ord(lst[i]) - ord('a')].append(i)
        i=0
        result=[]
        while i < len(lst):
            if not characters[ord(lst[i]) - ord('a')]:
                i+=1
                continue
            toenter=i
            boundary=characters[ord(lst[i]) - ord('a')][-1]
            j=i+1
            while j <boundary:
                if not characters[ord(lst[j]) - ord('a')]:
                    j=j+1
                    continue
                if ord(lst[toenter])>ord(lst[j]):
                    toenter=j
                boundary=min(boundary,characters[ord(lst[j]) - ord('a')][-1])
                j=j+1
            result.append(lst[toenter])
            characters[ord(lst[toenter]) - ord('a')]=[]
            i=toenter+1
        return ''.join(result)


print(Solution().removeDuplicateLetters("cbacdcbc"))
相关推荐
Black蜡笔小新1 分钟前
自动化AI算法训练服务器DLTM制造业AI质检工作站助力制造业实现AI智检
人工智能·算法·自动化
嵌入式小能手5 分钟前
飞凌嵌入式ElfBoard-进程间的通信之命名管道
linux·服务器·算法
sleven fung11 分钟前
MinerU与BabelDOC与KTransformers与OpenAI API库
开发语言·python·ai·langchain
小毛驴85020 分钟前
spring-boot-maven-plugin,maven-compiler-plugin 功能对比
java·python·maven
萤萤七悬24 分钟前
【Python笔记】AI帮实现CLI工具-使用argparse.ArgumentParser接收命令参数
开发语言·笔记·python
啦哈拉哈27 分钟前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
iCxhust33 分钟前
C# 命令行指令 查看二进制文件
开发语言·单片机·嵌入式硬件·c#·proteus·微机原理·8088单板机
csdn_aspnet38 分钟前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
诸葛务农1 小时前
道路行驶条件下电动汽车永磁电机的有效使用寿命及永磁体的失效和回收再利用(下)
java·开发语言·算法
snow@li1 小时前
AI:理解 大数据、算法、算力、电力、生成式AI、token 之间的关系
大数据·人工智能·算法