如题:假如给定了一串字符串 str='axzzyabccdacc' ,要求统计这串字符中每一个字符出现的次数。
初步想法是,首先准备一个空对象,然后遍历这个字符串,把字符当做对象的属性名,每一次遍历都判断对象中是否存在这个属性,如果存在就把属性值加一,如果不存在就给这个对象新添加这个属性,初始值为1。
let str = 'axzzyabccdacc';
function sum(str){
let obj = {};
for(let i in str){
if(obj[str[i]]){
obj[str[i]]++;
}else{
obj[str[i]] = 1;
}
}
return obj;
}
上面的if判断可以写成三元表达式:
obj[str[i]] ? obj[str[i]]++ : obj[str[i]] = 1;
跟小伙伴交流之后发现,其实上面并不需要使用下标,所以可以使用 for...of...进行遍历(推荐使用for...of...遍历数组,原因之后会更新相关文章进行阐述):
function sum(str){
let obj = {};
for(let val of str){
obj[val] ? obj[val]++ : obj[val] = 1;
}
return obj;
}
接着,切换另一种思路,遍历这个字符串,只需要把字符串按照当前字符进行分隔转化为数组,然后用数组的长度减去1,就是这个字符在字符串中出现的次数。
举个例子:
假如有字符串 let str = 'abcbd'; 我们把这个字符串按照字符 ‘b’ 进行分隔,str.split('b'),就会得到一个数组:['a','c','d'] 数组的长度为3,减去1,就是字符 ‘b’ 出现的次数。
let str = 'axzzyabccdacc';
function sum(str){
let obj = {};
for(let val of str){
obj[val] = str.split(val).length - 1;
}
return obj;
}
目前只想到这么多,欢迎交流。