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

题目描述

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

输出描述:

如果当前字符流没有存在出现一次的字符,返回#字符。

法1:

建立一个长度256的数组,当作字典

 1 # -*- coding:utf-8 -*-
 2 class Solution():
 3     # 返回对应char
 4     def __init__(self):
 5         self.s=""
 6         self.d = [0]*256
 7     def FirstAppearingOnce(self):
 8         for item in (list(self.s)):
 9             if(self.d[ord(item)]==1):
10                 return item
11         return ‘#‘
12     def Insert(self, char):
13         self.d[ord(char)]+=1
14         self.s+=char

法2:

python 内置函数

 1 # -*- coding:utf-8 -*-
 2 class Solution():
 3     # 返回对应char
 4     def __init__(self):
 5         self.s=""
 6     def FirstAppearingOnce(self):
 7         res = list(filter(lambda x:self.s.count(x)==1,self.s))
 8         return res[0] if res else ‘#‘
 9     def Insert(self, char):
10         self.s+=char

原文地址:https://www.cnblogs.com/zle1992/p/8253509.html

时间: 2024-11-04 13:02:50

54字符流中第一个不重复的字符的相关文章

字符流中第一个不重复的字符-剑指Offer

字符流中第一个不重复的字符 题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l". 输入描述 如果当前字符流没有存在出现一次的字符,返回#字符. 思路 模拟一个哈希表,长度为256,索引为字符的编码,初始化为-1,第一次出现时把该字符出现的位置赋给该数组元素,第二次出现时

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

题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符"google"时,第一个只出现一次的字符是"l". 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符. 题目解答 public class Solution { int[] hashtable=new int[256]; StringBuilde

54.字符流中第一个不重复的字符(python)

题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l". 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符. 1 class Solution: 2 # 返回对应char 3 def __init__(self): 4 self.stack=[] 5 def F

经典算法——字符流中第一个不重复的字符

题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符"google"时,第一个只出现一次的字符是"l". 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符. class Solution { public: int occurrence[256];//利用数组occurrence构造哈希表,将字符的

50-02 字符流中第一个不重复的字符( 时间空间效率的平衡)

题目描述: 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l". 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符.   测试用例: 1)功能测试(读入一个字符,读入多个字符,读入的所有字符都是唯一的,读入的所有字符都是重复出现的) 2)特殊输入测试(读入0个字符时)

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

题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符"google"时,第一个只出现一次的字符是"l". 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符. class Solution { public: //Insert one char from stringstream void Inser

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

一.题目 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符"google"时,第一个只出现一次的字符是"l". 二.解法 1 mport java.util.ArrayList; 2 import java.util.HashMap; 3 public class Solution { 4 HashMap<Ch

《剑指offer》字符流中第一个不重复的字符

[ 声明:版权所有,转载请标明出处,请勿用于商业用途.  联系信箱:[email protected]] 题目链接:http://www.nowcoder.com/practice/00de97733b8e4f97a3fb5c680ee10720?rp=3&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking 题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符&

剑指offer(五十四)之字符流中第一个不重复的字符

题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符"google"时,第一个只出现一次的字符是"l". 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符. 思路: 使用一个HashMap来统计字符出现的次数,同时用一个ArrayList来记录输入流,每次返回第一个出现一次的字符都是在这个Array