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

一、题目

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

二、解法

 1 mport java.util.ArrayList;
 2 import java.util.HashMap;
 3 public class Solution {
 4  HashMap<Character,Integer> map = new HashMap();
 5     ArrayList<Character> list = new ArrayList<Character>();
 6     //insert one char from stringstream
 7     public void Insert(char ch){
 8         if(map.containsKey(ch)){
 9             map.put(ch, map.get(ch)+1);
10         }else{
11             map.put(ch, 1);
12         }
13         list.add(ch);
14     }
15      public char FirstAppearingOnce()
16       {
17         char c = ‘#‘;
18         for(char key : list){
19             if(map.get(key) == 1){
20                 c = key;
21                 break;
22             }
23         }
24         return c;
25       }
26 }
时间: 2024-06-19 12:17:02

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

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

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

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

题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"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

《剑指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

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

题目:请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符"google"时,第一个只出现一次的字符是"l".  此题和[35]中找字符串中第一次出现一次的字符是类似的.所以详细过程这里不再赘述. 方案一:顺序扫描.时间复杂度O(N*N)+空间复杂度O(N).顺序扫描后,记录每一个字符出现的次数.然后顺序扫描数组得到第一

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

当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是'g'.当从该字符流中读出前六个字符"google"时,第一个只出现 1 次的字符是"l". 首先要记录一个字符出现的次数,为了实现O(1)查找,使用简易hash表存储.用occurences[256] 记录字符出现的次数.设置: occurences[i] = 0, 该字符未出现: occurences[i] = 1, 该字符出现一次: occurences[i] = 2, 该字符

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

题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出前六个字符"google"时,第一个只出现一次的字符是"l". 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符. 法1: 建立一个长度256的数组,当作字典 1 # -*- coding:utf-8 -*- 2 class Solution(): 3 #