练习一些内置对象问题
做这些问题思路很重要,没有思路可能一道题也写不出来,最重要的还是需要勤加练习。下面是我的一些思路:
1.把字符串中所有的o替换成!
str = 'abcoefoxyozzopp ';
这道题的思路:
1需要把o找出来,用到indexof属性,当indexof=-1时,代表、字符串中已经没有该元素了。
2.因为indexof只能显示首次出现位置的索引号,所以遍历遇到o时,要将o替换成!才可以一直遍历。
var str = 'abcoefoxyozzopp ';
while (str.indexOf("o") !== -1) {
str = str.replace("o", "!")
}
console.log(str);
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VWWz4hdP-1692623679159)(D:\课上笔记\js\images\11.png)]
2.找到数组[‘c’, ‘a’, ‘z’, ‘a’, ‘x’, ‘a’]中每一个a出现的位置
解题思路:
1.a出现的位置,需要用到indexof,但是indexof只能显示第一个,所以就是从第一个后面的位置再进行查找
2.当index=-1的时候,就没有a了,意味着遍历结束了,只要indexof!=-1,就继续往下找
var arr = ['c', 'a', 'z', 'a', 'x', 'a']
var index = arr.indexOf("a")
for (var i = 0; i < arr.length; i++) {
if (index !== -1) {
console.log(index);
index = arr.indexOf("a", index + 1)
}
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZlMydQgj-1692623679160)(D:\课上笔记\js\images\12.png)]
3.编写一个方法去掉一个数组[‘c’, ‘a’, ‘z’, ‘a’, ‘x’, ‘a’]的重复元素
解题思路:
1.首先建立一个新数组。新数组的indexof(旧数组的元素)是-1
2.没有的元素就添加到新数组里面,有的元素的indexof值就不是-1,就不添加
var newArr = [];
function unique(arr) {
for (var i = 0; i < arr.length; i++) {
if (newArr.indexOf(arr[i]) == -1) {
newArr.push(arr[i])
}
}
return newArr
}
var arr = ['c', 'a', 'z', 'a', 'x', 'a']
console.log(unique(arr));
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-44FBn4Ad-1692623679161)(D:\课上笔记\js\images\13.png)]
4.判断一个字符串中出现次数最多的字符,统计这个次数
s = 'abcoefoxyozzopp ';
解题思路:
1.遍历这个字符串,然后看里面的元素分别出现了多少次。
2.然后声明一个空对象,将元素与它出现的次数作为属性名和属性值放入这个空对象中。
3.然后遍历这个对象,比较属性值,最后输出出现次数最多的就可以了。
var str = 'abcoefoxyozzopp ';
var obj = {}
for (var i = 0; i < str.length; i++) {
var char = str.charAt(i)
if (obj[char]) {
obj[char]++;
} else {
obj[char] = 1
}
}
var ch = "",
max = 0;
for (var key in obj) {
if (max < obj[key]) {
max = obj[key]
ch = key
}
}
console.log("出现的次数最多的是" + ch + " " + "出现的次数是" + max);