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

题目描述

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

输出描述:

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

之前做过类似的题 这次开辟了128大小的数组来记录出现的次数 然后用list来记录流的字母
import java.util.LinkedList;
public class Solution {
    LinkedList<Character> list=new LinkedList<>();
    int[] array=new int[128];
    public void Insert(char ch)
    {
        array[ch] ++;
        if(array[ch] == 1){
            list.add(ch);
        }
    }
    //return the first appearence once char in current stringstream
    public char FirstAppearingOnce()
    {
        while (!list.isEmpty() && array[list.getFirst()] >= 2) list.removeFirst();
        if(list.isEmpty()) return '#';
        return list.getFirst();
    }
}

 

posted @ 2020-03-11 20:00  nlw  阅读(177)  评论(0编辑  收藏  举报