Python | Leetcode Python题解之第316题去除重复字母

打印 上一主题 下一主题

主题 982|帖子 982|积分 2946

题目:

题解:
  1. class Solution:
  2.     def removeDuplicateLetters(self, s: str) -> str:
  3.         vis = defaultdict(int)
  4.         cnt = defaultdict(int)
  5.         for ch in s: cnt[ch] += 1
  6.         queue = []
  7.         for ch in s:
  8.             if vis[ch] == 0:
  9.                 while queue and queue[-1] > ch and cnt[queue[-1]]:
  10.                     vis[queue.pop()] = 0
  11.                 if not queue or queue != ch: queue.append(ch)
  12.                 vis[ch] = 1
  13.             cnt[ch] -= 1
  14.         return "".join(queue)
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

一给

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表