首页 > 代码库 > 数组去重是面试中经常问到的问题
数组去重是面试中经常问到的问题
数组去重是面试中经常问到的问题
[html] view plain copy
- var arr=[1,3,4,52,4,5,4,8,7,6];
第一种方法:使用ES5中的indexOf进行去重:
[javascript] view plain copy
- function arr1(){
- var n=[];
- for(var i=0;i<arr.length;i++){
- if(n.indexOf(arr[i])==-1){
- n.push(arr[i]);
- }
- }
- return n;
- }//先定义一个空数组,然后遍历数组,使用indexOf检查是否含有重复元素,如果没有则插入到n中。使用此类方法应考虑ES5的兼容性问题
[javascript] view plain copy
运行结果如下:
第二种方法:先排序后然后再相邻比较去重
[javascript] view plain copy
- function arr3(){
- arr.sort();
- var re=[arr[0]];
- for(var i=1;i<arr.length;i++){
- if(arr[i]!==re[re.length-1]){
- re.push(arr[i]);
- }
- }
- return re;
- }
第三种方法:使用map去重
[javascript] view plain copy
- function arr4(arr){
- var map={};
- if(arr&&Array.isArray(arr)){
- for(var i=arr.length;i>=0;--i){
- if(arr[i] in map){
- arr.splice(arr[i],1);
- }else{
- map[arr[i]] = true;
- }
- }
- }
- return arr;
- }
效率最高:
数组去重是面试中经常问到的问题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。