剑指offer(C++)——字符流中第一个不重复的字符

题目描述

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

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

/*思路:由于字符只能从字符流中一个一个读取,可以定义一个哈希表来保存字符在字符流中的位置
用字符的ASCII码作为哈希表的键值,字符对应的位置作为哈希表的值。
初始哈希表值全为-1,当字符第一次从字符流中读取出来时,把它的位置保存在哈希表中,当再一次被读取出来时,就可以被忽略,此时哈希表值改为-2;
找第一个不重复的字符,只需遍历整个哈希表,找到最小的大于等于0的值对应的字符即可*/

class Solution
{
public:
       Solution() :index(0) {
              for (int i = 0; i < 256; ++i)
                     occurrence[i] = -1;                                   //初始化数组
       }
       //Insert one char from stringstream
       void Insert(char ch)
       {
              if (occurrence[ch] == -1)                                    // -1 表示该字符还没有出现
                     occurrence[ch] = index;
              else if (occurrence[ch] >= 0)                                // >=0 表示该字符出现了一次
                     occurrence[ch] = -2;
              ++index;
       }
       //return the first appearence once char in current stringstream
       char FirstAppearingOnce()
       {
              char ch = '#';                                                //不存在只出现一次的字符时,返回#
              int minIndex = numeric_limits<int>::max();                     //返回编译器允许的int型数最大值
              for (int i = 0; i < 256; ++i)
              {
                     if (occurrence[i] >= 0 && occurrence[i] < minIndex)
                     {
                           ch = (char)i;                                     //找到第一个不重复的字符
                           minIndex = occurrence[i];          
                     }
              }
              return ch;
       }
private:
       int occurrence[256];           //构建 Hash 表  
       int index;                     //记录字符在字符流中的位置
};


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值