牛客网 | 第一个只出现一次的字符位置

在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符的位置。若为空串,返回-1。位置索引从0开始

public class Solution {
    public int FirstNotRepeatingChar(String str) {
        HashMap<Character,Integer> hashMap = new HashMap<>();
        for (int i = 0; i < str.length(); i++) {
            if(hashMap.containsKey(str.charAt(i)))
            {
                int ci = hashMap.get(str.charAt(i));
                hashMap.put(str.charAt(i),++ci);
            }
            else
                hashMap.put(str.charAt(i),1);
        }

        for (int i = 0; i < str.length(); i++) {
            if(hashMap.get(str.charAt(i))==1)
                return i;
            
        }
        return -1;
    }
}


你可能感兴趣的:(java)