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

题目描述:

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

思路:

两种思路:

  1. 哈希表,建立哈希表,输入字符,记录字符,把每个字符都遍历到,对每个字符出现的次数计数,遍历完后就能依据哈希表知道首先仅出现次数为1的字符。
  2. 哈希表,但这里有所不同,首先将所有字符的哈希表关键值初始化为-1,输入数据,如果该数据的哈希表关键值是-1,则将对应的哈希表关键值改为输入的索引顺序值(大于等于零),如果该数据的哈希表的关键值大于等于零,则表示该数据已经出现过,意味着不可能是他们了,则将对应的哈希表关键值改为-2......,这样一直下去,当输入结束后,最后从头遍历哈希表,得到哈希表关键值的最小值就是最前面第一次出现的字符的位置,所以就能求出对应的字符。

方式1:

class solution
{
	private:
		int str="";
		int hash[256];
		for(int i=0;i<256;i++)
		{
			hash[i]=0;
		}
	public:
		
		void insert(char ch)
		{
			hash[ch]++;
			str+=ch;
		}
		char FindFirst(string str)
		{
			for(int i=0;i<str.length();i++)
			{
				if(hash[str[i]]==1)
					return str[i];
			}
		}
}

方式2:

class solution
{
	public:
		int hash[256];
		int index=0;
		for(int i=0;i<256;i++)
		{
			hash[i]=-1;
		}
		void insert(char ch)
		{
			/*将没有出现字符的哈希表值置为输入索引顺序值*/
			if(hash[ch]==-1)//元素没出现过
				hash[ch]=index;
			else 			//元素已经出现过
				hash[ch]=-2;
			index+;
		}
		
		char FindFirst()
		{
			int maxmum=Inter.Max_Value;//输入的最后的字符的索引顺序值
			int min=maxmum;
			char result;
			for(int i=0;i<256;i++)
			{
				if(hash[i]>=0&&hash[i]<=maxmum)
				{
					if(hash[i]<min)
					{
						min=hash[i];
						result=(char)i;
					}
						
				}
			}
			
			return result;
		}
}

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值