当前位置:首页 > 通信资讯 > 正文

java数组的去重排序(JAVA数组去重)

目录
  • 数组去重的场景
    • 1、ES6-set
    • 2、利用Map数据结构去重
    • 3、 嵌套循环+splice
    • 4、 forEach + indexOf
  • 总结

    数组去重的场景

    将数组var arr =[1,1,‘true',‘true',true,true,66,66,false,false,undefined,undefined, null,null, NaN, NaN, 0, 0, ‘a', ‘a',{},{}]中重复的值过滤掉

    1、ES6-set

    使用ES6中的set是最简单的去重方法

    ?
    1 2 3 4 5 6 7 <script> var arr=[1,2,3,4,1,2,3] //先将数组转换为set var set=new Set(arr) //再将set转换为数组 console.log(Array.from(set)) </script>

    2、利用Map数据结构去重

    创建一个空Map数据结构,遍历需要去重的数组,把数组的每一个元素作为key存到Map中。由于Map中不会出现相同的key值,所以最终得到的就是去重后的结果

    ?
    1 2 3 4 5 6 7 8 9 10 11 12 13 function shuzu(arr) { let map = new Map(); let array = new Array(); // 数组用于返回结果 for (let i = 0; i < arr.length; i++) { if(map .has(arr[i])) { // 如果有该key值 map .set(arr[i], true); } else { map .set(arr[i], false); // 如果没有该key值 array .push(arr[i]); } } return array ; }

    3、 嵌套循环+splice

    ?
    1 2 3 4 5 6 7 8 9 10 function shuzu(arr){ for(var i = 0 ; i < arr.length; i++){ for( var j = i + 1; j < arr.length; j++){ if( arr[i] === arr[j] ){ arr.splice(j,1); } } } return arr; }

    4、 forEach + indexOf

    ?
    1 2 3 4 5 6 7 8 9 function shuzu(arr){ var res = []; arr.forEach((val,index)=>{ if( res.indexOf(val) === -1 ){ res.push(val); } }); return res; }

    总结

    本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注服务器之家的更多内容!

    原文链接:https://blog.csdn.net/WangYong_Z/article/details/121023560

    如果您对该产品感兴趣,请填写办理(客服微信:xiaoxiongyidong)

    为您推荐:

    发表评论

    ◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。