这次给大家带来JS怎么实现数组去重算法,JS实现数组去重算法的注意事项有哪些,下面就是实战案例,一起来看一下。
测试用例:
arr = ["1",3,"1",1,4,5,1,"2",5,1,{"name":"li","age":20},2,4,3,{"name":"li","age":20},""];
方法一:借助于临时数组与indexOf , 算法复杂度为:O(n^2)
function unique1(arr){ var temp = []; for(var i=0; i<arr.length><p style="text-align: left;">测试结果:</p> <blockquote style="text-align: left;"><p style="text-align: left;">unique1(arr) : ["1", 3, 1, 4, 5, "2", Object { name="li", age=20}, 2, Object { name="li", age=20}, ""]</p></blockquote> <p style="text-align: left;">bug 无法区分对象</p> <p style="text-align: left;"><strong>方法二 : 用<a href="http://www.php.cn/wiki/48.html" target="_blank">JavaScript</a>中的<a href="http://www.php.cn/code/8123.html" target="_blank">Object对象</a>来当作哈希表</strong></p> <pre class="brush:php;toolbar:false">function unique2(arr){ var temp=[]; var hash={}; for(var i=0; i<arr.length><p style="text-align: left;">测试结果:</p> <blockquote style="text-align: left;"><p style="text-align: left;">unique2(arr) : ["1", 3, 4, 5, "2", Object { name="li", age=20}, ""]</p></blockquote> <p style="text-align: left;">bug : 无法区分: 1 和 "1"</p> <p style="text-align: left;">修改</p> <pre class="brush:php;toolbar:false">function unique2(arr){ var temp=[]; var hash={}; for(var i=0; i<arr.length><p style="text-align: left;">测试结果:</p> <blockquote style="text-align: left;"><p style="text-align: left;">unique2(arr) : ["1", 3, 1, 4, 5, "2", Object { name="li", age=20}, 2, ""]</p></blockquote> <p style="text-align: left;"><strong>方法三:先用sort对<a href="http://www.php.cn/code/54.html" target="_blank">数组排序</a>,然后借助临时数组,存储相同元素的最后一个,该方法只能用于纯Number类型数组</strong></p> <pre class="brush:php;toolbar:false">function unique3(arr){ arr.sort(function(a,b){ return a-b; }); var temp = []; for(var i=0;i<arr.length><p>相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!</p> <p>推荐阅读:</p> <p style="text-align: left;"><a href="http://www.php.cn/js-tutorial-397786.html" target="_blank">怎样用Vue+better-scroll实现字母索引导航</a><br></p> <p style="text-align: left;"><a href="http://www.php.cn/js-tutorial-397785.html" target="_blank">怎样实现Vue微信项目按需授权登录</a><br></p></arr.length>
以上就是JS怎么实现数组去重算法的详细内容,更多请关注php中文网其它相关文章!
Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号