第 125 题:如何将 [{id: 1}, {id: 2, pId: 1}, ...] 的重复数组(有重复数据)转成树形结构的数组 [{id: 1, child: [{id: 2, pId: 1}]}, ...] (需要去重)
如何去除数组项中重复的数组项
已知 :var arr = [5, 54, 1, 5, 1, 132, 56, 65, 132];
要求: 去除数组中重复的项目
结果: [5,54,1,132,56,65]
方法一
思路:
- 通过循环嵌套,将索引小的数组项依次和后面的数组项进行比较
- 出现相等情况,将后面的数组项删除(但保留位置)
- 通过 for in 将空数组项筛除(for in 会忽略 undefined 项)
var arr = [5, 54, 1, 5, 1, 132, 56, 65, 132];
for(var i = 0; i < arr.length; i++){
for(var j = i + 1; j < arr.length; j++){
if(arr[i] == arr[j]){
delete arr[j];
}
}
}
console.log(arr);
var arr2 = []
for (var key in arr) {
console.log(arr[key]);
arr2.push(arr[key]);
}
console.log(arr2);
方法二
var obj ={}
for(var i = 0; i< arr.length ;i++){
if(obj[arr[i]]){
//若属性名已经出现过,则if内的表达式的执行结果为true,
//对应的属性值进行加一操作;
obj[arr[i]] = ++obj[arr[i]];
}else{
//对象未出现过,则以arr数组中的数据为属性名,
//为obj创建一个键值对;
obj[arr[i]] = 1;
}
}
// console.log(obj);
// 执行结果: {1: 2, 5: 2, 54: 1, 56: 1, 65: 1, 132: 2}
var arr2 = [] ;
//创建一个空数列
for(var key in obj){
arr2.push(Number(key));
//依次推入属性名,并将属性名转成Number数据类型
}
console.log(arr2);
//执行结果 [1, 5, 54, 56, 65, 132]
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
上一篇: 第 126 题:扑克牌问题
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
@ZodiacSyndicate
var flatLs = [
{ id: 1},
{ id: 2},
{ id: 3},
{ id: 4, pid: 1 },
{ id: 5, pid: 3 },
{ id: 6, pid: 2 },
{ id: 7, pid: 4 },
{ id: 8, pid: 3 },
{ id: 9, pid: 4 }
]
const flat2tree = flatLs => {
flatLs.forEach(item => {
if (!item.pid) {
item.pid = 0;
} else {
const index = flatLs.findIndex(_item => _item.id === item.pid)
if (index !== -1) {
flatLs[index].children = flatLs[index].children || []
flatLs[index].children.push(item)
}
}
})
return flatLs.filter(item => item.pid === 0)
}
为什么代码没有缩进,[笑哭]
是这个意思吗,不太清楚,轻喷哈
哈希表,时间复杂度O(n)