題目:在一個字符串(1<=字符串長度<=10000方面,全部由字母組成)中找到第一個只出現(xiàn)一次的字符,并返回它的位置
public class Solution {
public int FirstNotRepeatingChar(String str) {
char[] chars = str.toCharArray();
int[] nums = new int['z'+1];
for(char ch : chars){
nums[(int)ch]++;
}
for(int i = 0; i < chars.length; i++){
if(nums[(int)chars[i]] == 1){
return (char)(i);
}
}
return -1;
}
}
思路:
維護一個數(shù)組記錄所有訪問的字符出現(xiàn)的次數(shù),然后遍歷這個數(shù)組找到第一個出現(xiàn)一次的字符