1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 算法试题 - 找出字符流中第一个不重复的元素

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

时间:2021-10-14 19:23:00

相关推荐

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

题目

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

第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l"。

思路

思路:引入两个辅助存储空间。一个Dict存储当前出现的字符以及字符出现的次数,一个List存储当前出现字符。

然后每次比较List的第一个字符在Dict中对应的次数,如果为1则输出这个字符,如果不为1则弹出这个字符比较下一个字符。

答案

标准答案

# -*- coding:utf-8 -*-class Solution:# 返回对应chardef __init__(self):# 存储当前字符self.alist = []# 存储当前字符及其出现次数,出现大于1次,就设成2次self.adict = {}def FirstAppearingOnce(self):# write code herewhile 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 hereif char not in self.adict.keys():self.adict[char] = 1self.alist.append(char)else:self.adict[char] = 2

自我实现答案

class Firstone:def __init__(self, s):self.di = {}self.li = []self.s = sdef ins(self):for i in self.s:if not self.di.get(i, ""):self.di[i] = 1self.li.append(i)else:self.di[i] = 2return self.di, self.lidef findfirstone(self):for i in self.li:if self.di[i] == 1:return ireturn 0findone = Firstone(s)print(findone.ins())print(findone.findfirstone())

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。