练习牛客网笔试题--前端js--14-移除数组中的元素,返回原数组
// 题目描述
// 移除数组 arr 中的所有值与 item 相等的元素,直接在给定的 arr 数组上进行操作,并将结果返回
// 输入 [1, 2, 2, 3, 4, 2, 2], 2
// 输出 [1, 3, 4]
1.自己的练习
function removeWithoutCopy(arr, item) {
while(true) {
var index = arr.indexOf(item);
if(index === -1) break;
arr.splice(index, 1);
}
return arr;
}
2.题解
1. 采用while循环
function removeWithoutCopy(arr, item) {
while (arr.indexOf(item) !== -1) {
arr.splice(arr.indexOf(item), 1);
}
return arr;
}
2.具有收集删除信息列表的代码
function removeWithoutCopy(arr, item) {
var array = []
for (var i = 0;i < arr.length;i++) {
if (arr[i] === item) {
array.push(i) //arr要删除的项被收集
}
}
for (var j in array) {
arr.splice(array[j]-j,1)
}
return arr
// return array
//在正向遍历时,考虑位置影响
}
3.非得要正向遍历删除的方法:
function removeWithoutCopy(arr, item) {
for (var i = 0;i < arr.length;i++) {
if (arr[i] === item) {
arr.splice(i,1)
i-- //删除后使得遍历不会缺少项,同时不用考虑位置变化了
}
}
return arr
}
4. 使用逆向检索的方法
function removeWithoutCopy(arr,item) {
for (var i = arr.length-1;i >= 0;i--) {
if (arr[i] === item) {
arr.splice(i,1)
// console.log("删除了第"+i+"项")
}
}
return arr
}