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

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

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)


全部评论

相关推荐

菜菜咪:1. 可以使用简历网站的模版,美观度会更好一点 2. 邮箱可以重新申请一个,或者用qq邮箱的别名,部分hr可能会不喜欢数字邮箱 3. 项目经历最好分点描述,类似的项目很多,可以参考一下别人怎么写的 4. 自我评价可加可不加,技术岗更看重技术。最后,加油,优秀士兵
点赞 评论 收藏
分享
小红书 后端选手 n*16*1.18+签字费期权
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务