题解 | #字符流中第一个不重复的字符#

字符流中第一个不重复的字符

https://www.nowcoder.com/practice/00de97733b8e4f97a3fb5c680ee10720

空间复杂度O(1)
# -*- coding:utf-8 -*-
class Solution:
    def __init__(self):
        # 这两个都没有重复的字符,空间复杂度O(1)
        self.repeat = set() # 记录已重复的字符
        self.s = [] # 记录尚未重复的字符(首位就是第一个不重复的字符)
    def FirstAppearingOnce(self):
        return '#' if not self.s else self.s[0]
    def Insert(self, char):
        if char not in self.s: # 不在s中,再判断在不在repeat中
            if char not in self.repeat:
                self.s.append(char)
        else: # 在s中,从s中去掉,再添加到repeat
            self.s.remove(char)
            self.repeat.add(char)


全部评论

相关推荐

LZHR:老哥你从投递简历测评完到一面中间隔了多久呀,我这边已经过了五天了仍显示简历筛选中是不是就是挂了
腾讯求职进展汇总
点赞 评论 收藏
分享
合适才能收到offe...:招聘上写这些态度傲慢的就别继续招呼了,你会发现hr和面试官挺神的,本来求职艰难就可能影响一些心态了,你去这种公司面试的话,整个心态会炸的。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务