//方法一:时间复杂度为O(n)。通过创建空的obj对象,遍历数组的时候查找obj对象中是否有值,没有的话以该元素创建一个属性并赋值,同时遍历的数组元素push进res数组
Array.prototype.unique = function () {
let obj = {};
let res = [];
for(let i = 0;i < this.length;i++){
if(!obj[this[i]]){
obj[this[i]] = {}; //json[this[i]]可以随意赋值
res.push(this[i]);
}
}
return res;
}
console.log([1,1,2,2,3].unique()) //[1,2,3]
//方法二: 将res数组中上一个元素与原数组中的每个元素进行比较,将不同于上一个元素的元素放入res数组中
第二种方法不行。因为sort方法不是按大小排序的,是默认排序顺序是在将元素转换为字符串,然后比较它们的UTF-16代码单元值序列时构建的。https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/sort
Array.prototype.unique = function () {
console.log(this)
let res = [this[0]];
for(let i = 0;i < this.length;i++){
if(this[i] != res[res.length-1]){
res.push(this[i]);
}
}
return res;
}
console.log([1,1,2,2,3].sort().unique())
我的微信公众号:天字一等
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。