Loading

387. 字符串中的第一个唯一字符

题目

 

代码

class Solution {
public:
    int firstUniqChar(string s) {
        std::map<char,int> table;
        //先用map存储,value是出现的次数
        for(int i=0;i<s.size();i++)
        {
            table[s[i]]++;
        }
        //从头开始遍历数组,如果发现它出现的次数为1,则返回
        for(int i=0;i<s.size();i++)
        {
            if(table[s[i]]==1)
                return i;
        }
        
        return -1; 
    }
};

 

思路

直接用map保存出现的次数,然后从字符串头开始遍历,第一个在map中值为1即为所求。

posted @ 2018-09-14 08:11  李正浩  阅读(84)  评论(0编辑  收藏  举报