首页 > 语言 > JavaScript > 正文

JavaScript学习笔记之数组去重

2024-05-06 14:59:57
字体:
来源:转载
供稿:网友

推荐阅读: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;}            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选