您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

js能力测评经典题中分析数组类型的用法_附代码

2025/8/9 9:22:48发布27次查看
最近在做中的js能力测评经典题,因此按照自己的能力和想法进行了总结,此篇文章主要是数组类的总结。
1、找出元素item在给定数组中的位置:arr.indexof(item);
2、计算给定数组arr中所有元素的总和:arr.foreach(function(e){sum=sum+e;})
注:数组名.foreach(function(数组元素,元素索引,额外定义的数组){函数体}) //返回的仍是调用的数组
数组名.map(function(数组元素){函数体})  //返回的是新数组,它不修改调用的数组;
3、移除数组arr中的所有制与item相等的元素,不要直接修改数组arr,结果返回新的数组。
function remove(arr, item) { var newarray=[]; arr.foreach(function(e){ if(e!=item){ newarray.push(e); } }) return newarray;}
4、移除数组arr中的所有与item相等的元素,直接在给定的数组上修改,并将结果返回。
//方法一:从前往后遍历删除元素function removewithoutcopy(arr,item){ for(i=0;i<arr.length;i++){ if(item==arr[i]){ arr.splice(i,1); //splice(定位元素索引[,删除元素个数,添加元素]) i--;//i--的目的是因为删除了一个元素,在回到for时需要i++,会跳过一个元素 } }}//方法二:从后往前遍历删除元素function removewithoutcopy(arr,item){ for(i=arr.length-1;i>=0;i--){ if(item==arr[i]){ arr.splice(i,1); //删除时无需进行位移 } }}
注:数组名.splice(索引[,个数,添加元素]),splice意味着直接在原有数组上进行修改,返回值为删除元素组成的数组。例:var a=[1,2,3,4,5];a.splice(3,1)//返回[4],a为[1,2,3,5]
5、在数组arr末尾添加元素item,不要直接在arr上修改,返回新的数组。
//方法一:直接使用数组的concat追加新的item,并返回新的数组function append(arr, item) { return arr.concat(item);}//方法二:利用slice对原数组进行切分,产生新的数组,在对新数组进行push即可function append(arr, item) { var newarray=arr.slice(0); newarray.push(item); return newarray;}//方法三:利用数组的map创建新的数组,最后对新数组push(item)即可function append(arr, item) { var newarray=arr.map(function(e){ return e; }) newarray.push(item); return newarray;}//方法四:定义一个空数组,利用for/foreach进行赋值,再对新数组push(item)即可function append(arr, item) { var newarray=[]; arr.foreach(function(e){ newarray.push(e); }) newarray.push(item); return newarray;}
6、删除数组arr最后一个元素,不要直接修改数组arr,结果返回新的数组:return arr.slice(0,arr.length-1);
7、在数组 arr 开头添加元素 item。不要直接修改数组 arr,结果返回新的数组:var newarray=arr.slice(0);newarray.unshift(item)
8、删除数组 arr 第一个元素。不要直接修改数组 arr,结果返回新的数组:return arr.slice(1);
9、合并数组 arr1 和数组 arr2。不要直接修改数组 arr,结果返回新的数组:return arr1.concat(arr2);
10、在数组 arr 的 index 处添加元素 item。不要直接修改数组 arr,结果返回新的数组:var newarray = arr.slice(0); newarray.splice(index,0,item); return newarray;
11、统计数组 arr 中值等于 item 的元素出现的次数。
function count(arr, item) { var count=0; arr.foreach(function(e){ if(e==item) count+=1; }); return count;}
12、找出数组 arr 中重复出现过的元素。输入:[1, 2, 4, 4, 3, 3, 1, 5, 3]。输出:[1, 3, 4]。
//方法一:利用indexof和lastindexof进行判断function duplicates(arr) { var result=[]; arr.foreach(function(e){ if(arr.indexof(e)!=arr.lastindexof(e) && result.indexof(e)==-1){ result.push(e); } }); return result;}//方法二:利用双重for循环进行判断function duplicates(arr) { var result=[]; for(i=0;i<arr.length-1;i++){ for(k=0;k<result.length;k++){ if(arr[i]==result[k]) break; } if(k!=result.length) continue; for(j=i+1;j<arr.length;j++){ if(arr[i]==arr[j]){ result.push(arr[i]); break; } } } return result;}
13、为数组 arr 中的每个元素求二次方。不要直接修改数组 arr,结果返回新的数组。
//方法一:定义空数组,对arr进行遍历赋值function square(arr) { var newarr=[]; arr.foreach(function(e){ newarr.push(e*e); }); return newarr;}//方法二:直接使用map产生新的数组function square(arr) { return arr.map(function(e){ return e*e; })}
14、在数组 arr 中,查找值与 item 相等的元素出现的所有位置
function findalloccurrences(arr, target) { var newarray=[]; arr.foreach(function(e,i){ if(e==target) newarray.push(i); }) return newarray;}
在js经典题中,以上便是所有数组的题型,接下来便是编码规范、函数模块。
相关推荐:
bootstrap经典案例分析
php字符串操作经典入门
视频教程:前端js开发27个经典实战
以上就是js能力测评经典题中分析数组类型的用法_附代码的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product