TOP

算法试题 - 找出字符流中第一个不重复的元素

题目

题目:请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,
第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l"。

思路

思路:引入两个辅助存储空间。一个Dict存储当前出现的字符以及字符出现的次数,一个List存储当前出现字符。
然后每次比较List的第一个字符在Dict中对应的次数,如果为1则输出这个字符,如果不为1则弹出这个字符比较下一个字符。

答案

标准答案

# -*- coding:utf-8 -*-
class Solution:
    # 返回对应char
    def __init__(self):
        # 存储当前字符
        self.alist = []
        # 存储当前字符及其出现次数,出现大于1次,就设成2次
        self.adict = {}

    def FirstAppearingOnce(self):
        # write code here
        while len(self.alist) > 0 and self.adict[self.alist[0]] == 2:
            self.alist.pop(0)
        if len(self.alist) == 0:
            return '#'
        else:
            return self.alist[0]

    def Insert(self, char):
        # write code here
        if char not in self.adict.keys():
            self.adict[char] = 1
            self.alist.append(char)
        else:
            self.adict[char] = 2

 

自我实现答案

class Firstone:
    def __init__(self, s):
        self.di = {}
        self.li = []
        self.s = s

    def ins(self):
        for i in self.s:
            if not self.di.get(i, ""):
                self.di[i] = 1
                self.li.append(i)
            else:
                self.di[i] = 2
        return self.di, self.li

    def findfirstone(self):
        for i in self.li:
            if self.di[i] == 1:
                return i
        return 0


findone = Firstone(s)

print(findone.ins())
print(findone.findfirstone())

 

posted @ 2019-05-02 16:31  羊驼之歌  阅读(149)  评论(0编辑  收藏  举报