强烈推荐30个原生JavaScript的demo,包括canvas时钟特效、自定义视频播放器、搜索栏快速匹配、fetch访问资源、console调试技巧等,巩固基础和面试的宝贵资料,先fork后学习,详见点击打开链接,欢迎点赞~~~谢谢,共同进步学习!
题目描述
移除数组 arr 中的所有值与 item 相等的元素,直接在给定的 arr 数组上进行操作,并将结果返回
示例1
输入
[1, 2, 2, 3, 4, 2, 2], 2
输出
[1, 3, 4]
解法:
一.不直接修改数组
题目描述
移除数组 arr 中的所有值与 item 相等的元素。不要直接修改数组 arr,结果返回新的数组
输入例子:
remove([1, 2, 3, 4, 2], 2)
输出例子:
[1, 3, 4]
方法1
[javascript] view plain copy
- function remove(arr, item) {
- var result=[];
- for(var i=0; i<arr.length; i++){
- if(arr[i]!=item){
- result.push(arr[i]);
- }
- }
- return result;
- }
方法2
[javascript] view plain copy
- function remove(arr, item) {
- var result=[];
- arr.forEach(function(element){
- if(element!=item){
- result.push(element);
- }
- });
- return result;
- }
forEach的用法可参考:
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach
方法3
function removeWithoutCopy(arr, item) {
return arr.filter(function(ele){
return ele!=item;
})
}
二.直接修改数组
题目描述
移除数组 arr 中的所有值与 item 相等的元素,直接在给定的 arr 数组上进行操作,并将结果返回
输入例子:
removeWithoutCopy([1, 2, 2, 3, 4, 2, 2], 2)
输出例子:
[1, 3, 4]
方法1:
[javascript] view plain copy
- function removeWithoutCopy(arr, item) {
- for(var i = 0; i < arr.length; i++){
- if(arr[i] == item){
- //splice方法会改变数组长度,当减掉一个元素后,后面的元素都会前移,因此需要相应减少i的值
- arr.splice(i,1);
- i--;
- }
- }
- return arr;
- }
或
[javascript] view plain copy
- function removeWithoutCopy(arr, item) {
- for(var i=0; i<arr.length;){
- if(item==arr[i]){
- arr.splice(i,1);
- }else {
- i++;
- }
- }
- return arr;
- }
方法2:
[javascript] view plain copy
- function removeWithoutCopy(arr, item) {
- for(var i=arr.length-1;i>=0;i--)
- {
- if(arr[i]==item)
- {
- arr.splice(i,1);
- }
- }
- return arr;
- }
- 倒着检测;不用考虑位置影响