在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).
public class Solution {
public int FirstNotRepeatingChar(String str) {
if(str == null || str.length() ==0){
return -1;
}
char[] list = str.toCharArray();
Map<Character,Integer> map = new HashMap<>();
for (int i = 0; i < list.length; i++) {
if(map.containsKey(list[i])){
int time = map.get(list[i]);
map.replace(list[i],time,time+1);
}else{
map.put(list[i],1);
}
}
for (int i = 0; i < list[i]; i++) {
int time = map.get(list[i]);
if(time == 1){
return i;
}
}
return -1;
}
}