描述
给定一个列表,该列表中的每个元素要么是个列表,要么是整数。将其变成一个只包含整数的简单列表。
如果给定的列表中的要素本身也是一个列表,那么它也可以包含列表。
样例
样例 1:
输入:
列表 = [[1,1],2,[1,1]]
输出:
[1,1,2,1,1]
解释:将其变成一个只包含整数的简单列表。
样例 2:
输入:
列表 = [1,2,[1,2]]
输出:
[1,2,1,2]
解释:将其变成一个只包含整数的简单列表。
样例 3:
输入:
列表 = [4,[3,[2,[1]]]]
输出:
[4,3,2,1]
解释:将其变成一个只包含整数的简单列表。
比较直观采用DFS做,直接上代码。
/**
* // This is the interface that allows for creating nested lists.
* // You should not implement it, or speculate about its implementation
* public interface NestedInteger {
*
* // @return true if this NestedInteger holds a single integer,
* // rather than a nested list.
* public boolean isInteger();
*
* // @return the single integer that this NestedInteger holds,
* // if it holds a single integer
* // Return null if this NestedInteger holds a nested list
* public Integer getInteger();
*
* // @return the nested list that this NestedInteger holds,
* // if it holds a nested list
* // Return null if this NestedInteger holds a single integer
* public List<NestedInteger> getList();
* }
*/
public class Solution {
public List<Integer> flatten(List<NestedInteger> nestedList) {
List<Integer> list = new ArrayList<>();
helper(nestedList,list);
return list;
}
public void helper(List<NestedInteger> nestedList,List<Integer> list){
if(nestedList.size()==0){
return;
}
for (NestedInteger nestedInteger:nestedList) {
if (nestedInteger.isInteger()){
list.add(nestedInteger.getInteger());
}else{
helper(nestedInteger.getList(),list);
}
}
}
}