推荐阅读:JavaScript学习笔记之数组的增、删、改、查
JavaScript学习笔记之数组求和方法
JavaScript学习笔记之数组随机排序
话说面试常会碰到面试官会问JavaScript实现数组去重的问题,最近刚好在学习有关于JavaScript数组相关的知识,趁此机会整理了一些有关于JavaScript数组去重的方法。
下面这些数组去重的方法是自己收集和整理的,如有不对希望指正文中不对之处。
双重循环去重
这个方法使用了两个for循环做遍历。整个思路是:
构建一个空数组用来存放去重后的数组
外面的for循环对原数组做遍历,每次从数组中取出一个元素与结果数组做对比
如果原数组取出的元素与结果数组元素相同,则跳出循环;反之则将其存放到结果数组中
代码如下:
Array.prototype.unique1 = function () {// 构建一个新数组,存放结果var newArray = [this[0]];// for循环,每次从原数组中取出一个元素// 用取出的元素循环与结果数组对比for (var i = 1; i < this.length; i++) {var repeat = false;for (var j=0; j < newArray.length; j++) {// 原数组取出的元素与结果数组元素相同if(this[i] == newArray[j]) {repeat = true;break;}}if(!repeat) {// 如果结果数组中没有该元素,则存放到结果数组中newArray.push(this[i]);}}return newArray;}
假设我们有一个这样的数组:
var arr = [1,2,3,4,'a','b',1,3,4,56,32,34,2,'b','c',5,'1',`2`];arr.unique1(); // [1, 2, 3, 4, "a", "b", 56, 32, 34, "c", 5]
据说这种方法比较耗时,费性能。简单做个测试(测试方法写得比较拙逼):
function test () {var arr = [];for (var i = 0; i < 1000000; i++) {arr.push(Math.round(Math.random(i) * 10000));}doTest(arr, 1);}function doTest(arr, n) {var tStart = (new Date()).getTime();var re = arr.unique1();var tEnd = (new Date()).getTime();console.log('双重循环去重方法使用时间是:' + (tEnd - tStart) + 'ms');return re;}test();
在Chrome控制器运行上面的代码,测试双重循环去重所费时间:11031ms。
上面的方法可以使用forEach()方法和indexOf()方法模拟实现:
function unique1() {var newArray = [];this.forEach(function (index) {if (newArray.indexOf(index) == -1) {newArray.push(index);}});return newArray;}
通过unique1.apply(arr)或unique1.call(arr)调用。不过这种方法效率要快得多,同样的上面测试代码,所费时间5423ms,几乎快了一半。
排序遍历去重
先使用sort()方法对原数组做一个排序,排完序之后对数组做遍历,并且检查数组中的第i个元素与结果数组中最后一个元素是否相同。如果不同,则将元素放到结果数组中。
Array.prototype.unique2 = function () {// 原数组先排序this.sort();// 构建一个新数组存放结果var newArray = [];for (var i = 1; i < this.length; i++) {// 检查原数中的第i个元素与结果中的最后一个元素是否相同// 因为排序了,所以重复元素会在相邻位置if(this[i] !== newArray[newArray.length - 1]) {// 如果不同,将元素放到结果数组中newArray.push(this[i]);}}return newArray;}
新闻热点
疑难解答
图片精选