JS如何遍历带有子集的数组集合(嵌套数组)
作者:薄荷琴糖
这篇文章主要介绍了JS如何遍历带有子集的数组集合(嵌套数组)问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
JS遍历带有子集的数组集合
js中两种for循环:
for(var i in obj) for(var i=0;i<obj.length;i++)
区别:
for(var i in obj)
- 是增强for循环,是不使用下标的一种遍历方式,简单高效,缺点是不能使用下标。
- 如果想要循环遍历一个json对象就用第一个
- 如果想循环遍历一个数组对象就用第二个
for(var i in obj)
- 1.遍历数组时,i是索引值,arr[i]是索引号对应的值。
- 2.遍历字符串时,i是索引值,arr[i]是索引号对应的字符。
- 3.遍历json对象时,i是冒号前面的值,json[i]是冒号后面的值。
遍历嵌套数组(递归)【判断子集】
traversal(dataInfo)//dataInfo是要循环遍历的集合 //遍历方法 function traverse(data) { for (var i in data) { if (data[i].children) { traverse(data[i].children) } if (!data[i].children.length) { delete data[i].children; } } }
例如我的集合如下
我要获取其中的Name并输出
代码如下:
traversal(dataInfo)//dataInfo是要循环遍历的集合 //遍历方法 function traverse(data) { for (var i in data) { alert(data[i].Name) if (data[i].children) { traverse(data[i].children) } if (!data[i].children.length) { delete data[i].children; } } }
使用JS找出给定数组的所有子集
题目描述
给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。
说明:解集不能包含重复的子集。
解题思路
- 采用二进制的思路,全0对应空集,全1对应全集
- 根据数组长度决定二进制位数
- 遍历二进制各值,使用按位与操作符,生成数组的子集
解题代码
/** * @param {number[]} nums * @return {number[][]} */ var subsets = function(nums) { let res = [], len = nums.length; for (let i = 0; i < (1 << len); i++) { let arr = []; for (let j = 0; j < len; j++) { if (i & (1 << j)) arr.push(nums[j]); } res.push(arr); } return res; };
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。