題目描述
給定一個字符串,找到它的第一個不重複的字符,並返回它的索引。如果不存在,則返回 -1。
案例:
s = "leetcode"
返回 0.
s = "loveleetcode",
返回 2.
注意事項:您可以假定該字符串只包含小寫字母。
解法
首先是我自己寫的很LOW的解法:
class Solution {
public:
int firstUniqChar(string s) {
int n = s.size()-1;
bool flag1 = true;
bool flag2 = true;
vector<char> same;
if(n==0) return 0;
for(int i=0;i<=n;i++){
for(int j=i+1;j<=n;j++){
if(s[i]==s[j]){
same.push_back(s[j]);
flag1 = false;
break;
}
}
for(int k=0;k<same.size();k++){
if(s[i]==same[k]) {
flag2 = false;
break;
}
}
if(flag1&&flag2) return i;
flag1 = true;
flag2 = true;
}
return -1;
}
};
思路很簡單,就是很單純地使用循環嵌套來一個一個判斷字母是否唯一,使用兩個flag分別判斷當前字母是否重合和當前字母曾經是否重合,如果兩個flag都通過則返回當前字母的位置。很顯然這段代碼的時間複雜度有O(n^2),並不理想。
然後就是比較好的的解法:
class Solution {
public:
int firstUniqChar(string s) {
int alphabet[26];
memset(alphabet,0,sizeof(int)*26);
for(int i=0;i<s.size();i++) alphabet[s[i]-'a']++;
for(int i=0;i<s.size();i++) if(alphabet[s[i]-'a']==1) return i;
return -1;
}
};
可以想到利用int數組將26個字母作爲簡單的哈希表,大大降低了時間複雜度。