* // 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(); * } */ publicclassimplementsIterator<Integer> {
private Stack<NestedInteger> stack = new Stack<NestedInteger>();
public(List<NestedInteger> nestedList){
for (int i = nestedList.size() - 1; i > -1; i--) { stack.push(nestedList.get(i)); }
}
public Integer next(){
return stack.pop().getInteger();
}
publicbooleanhasNext(){
while ( !stack.empty() && !stack.peek().isInteger()) { NestedInteger nestedInteger = stack.pop(); List<NestedInteger> list = nestedInteger.getList(); for (int i = list.size() - 1; i > -1; i--) { stack.push(list.get(i)); } } return !stack.empty();
}
}
* Your NestedIterator object will be instantiated and called as such: * NestedIterator i = new NestedIterator(nestedList); * while (i.hasNext()) v[f()] = i.next(); */
近期评论