在这之前写了个版本,测试发现有问题,并不是所有的都可以,这就很蒙蔽了。果然都是实践出真理。
为题代码如下:
function norepeat(arr) {
for (var i = 0; i < arr.length; i++) {
for (var j = 1 + i; j < arr.length; j++) {
if (arr[i] == arr[j]) {
arr.splice(j, 1);
}
}
}
console.log(arr)
}
var arr = [2, 3, 1, 5, 2, 3, 6, 8, 1]
// norepeat(arr);
这个数组咋一样,一测试时没什么问题,当多个重复的值出现就有问题了。比如这种arr[1,1,1,1,1,2,2,2,2,2,3,3,3,3,3],所以迫切的需要解决这个问题。
下面我们用两个函数来解决上面的问题
1、我们先封装一个has(arr,num)的函数来判断arr里面是否包含这个num。返回布尔值。
function has(arr,num){
for(var i=0;i<arr.length;i++){
if(arr[i] === num){
return true;
}
}
return false;
}
2、将数组的重复元素去掉,并返回新的数组
function norepeat(myarr){
var sArr = [];
for(var i=0;i<myarr.length;i++){
if(!has(sArr,myarr[i])){
sArr.push(myarr[i])
}
}
return sArr;
}
norepeat(arr);
这个就完美的解决了这个问题。