如果当前字符流没有存在出现一次的字符,返回#字符。
public class Solution {
private int[] occurrence=new int[256];//哈希表
private int count=0;//字符在字符流中的位置
public Solution(){
//最开始,哈希表中所有元素都初始化为-1
for(int i=0;i<256;i++){
occurrence[i]=-1;
}
}
//Insert one char from stringstream
public void Insert(char ch)
{
if(occurrence[ch]==-1){//如果第一次从字符流中读出字符ch
occurrence[ch]=count;
}
else{//如果再次从字符流中读出字符ch
occurrence[ch]=-2;
}
count++;
}
//return the first appearence once char in current stringstream
public char FirstAppearingOnce()
{
//遍历哈希表,找出最小的大于等于0的元素,返回其下标对应字符
int minIndex=256;
char ch='#';
for(int i=0;i<256;i++){
if(occurrence[i]>=0 && occurrence[i]<minIndex){
minIndex=occurrence[i];
ch=(char) (i);
}
}
return ch;
}
}
本文介绍了一个用于处理字符流的Java类,该类能够实时检测并返回字符流中首次只出现一次的字符。通过使用哈希表记录每个字符的出现情况,实现了高效的查找。

被折叠的 条评论
为什么被折叠?



