在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。
示例:
s = “abaccdeff”
返回 “b”
s = “”
返回 " "
题目来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/di-yi-ge-zhi-chu-xian-yi-ci-de-zi-fu-lcof
var firstUniqChar = function(s) {
if(s.length === 1){
return s;
}
let arr = s.split('');
for(let i = 0; i < arr.length; i++){
let arr1 = arr.slice(0, i);
let arr2 = arr.slice(i+1);
if(arr1.indexOf(arr[i]) === -1 && arr2.indexOf(arr[i]) === -1){
return arr[i];
}
}
return ' ';
};
解题步骤
先把字符串用split方法切割成数组先
遍历一下数组
然后新建两个数组,一个数组包含遍历到此时i位置前面的元素(不包含i)
另一个数组包含遍历到此时i位置后面的元素(同样不包含i)
然后用js的indexof方法(没有找到则会返回-1),判断遍历到此时i索引位置的元素是否同时不在新建的两个数组里出现