給定一個 N 叉樹,返回其節點值的前序遍歷。
例如,給定一個?3叉樹
?:
返回其前序遍歷:?[1,3,5,6,2,4]
。
思路:先放入自己,再依次遍歷孩子。
/*
// Definition for a Node.
class Node {public int val;public List<Node> children;public Node() {}public Node(int _val) {val = _val;}public Node(int _val, List<Node> _children) {val = _val;children = _children;}
};
*/class Solution {List<Integer> res=new ArrayList<Integer>();public List<Integer> preorder(Node root) {helper(root);return res;}public void helper(Node root){if (root==null) return;res.add(root.val);for (int i = 0; i <root.children.size() ; i++) {helper(root.children.get(i));}}
}
?