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

题目描述:

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

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

 

测试用例:

1)功能测试(读入一个字符,读入多个字符,读入的所有字符都是唯一的,读入的所有字符都是重复出现的)

2)特殊输入测试(读入0个字符时)

解题思路:

1)使用哈希表

class Solution
{
public:
    //定义构造函数
    Solution():index(0){
        for(int i=0;i<256;i++)
            occurrence[i]=-1;  //初始化为-1,表示还字符没有出现过
    }
  //Insert one char from stringstream
    void Insert(char ch)
    {
        if(occurrence[ch]==-1)
             occurrence[ch]=index;
        else if(occurrence[ch]>=0)  //表示该字符已经出现过一次
            occurrence[ch]=-2;
        index++;
    }
  //return the first appearence once char in current stringstream
    char FirstAppearingOnce()
    {
        //如果字符流为空的时候
        char ch=‘#‘;  //认真读题,注意题目要求的返回值
        int minV = numeric_limits<int>::max();  //初始化为int能表示的最大值
        for(int i=0;i<256;i++){
            if(occurrence[i]>=0 && occurrence[i]< minV){
                ch=char(i); //将ASCII码转为对应的字符
                minV = occurrence[i];
            }
        }
        return ch;

    }
private:
    int occurrence[256];
    int index;  //表示字符在字符流中的位置
};

std::numeric_limits为模板类,使用时需要添加头文件#include<limits>

比较常用的使用是对于给定的基础类型用来判断在当前系统上的最大值、最小值。

支持的基础算术类型包括如下



2)其他一些方法,大多是将字符流存起来,string或者vector,然后寻找的时候遍历字符流的所有字符,判断哈希表或者map中字符出现的次数。无论是空间复杂度还是时间复杂度都比方法1高

原文地址:https://www.cnblogs.com/GuoXinxin/p/10551673.html

时间: 2024-10-08 14:33:41

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

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

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

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

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

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

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

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

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

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 #

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

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