码迷,mamicode.com
首页 > 其他好文 > 详细

589-N叉树的前序遍历

时间:2019-05-22 20:38:55      阅读:99      评论:0      收藏:0      [点我收藏+]

标签:ret   nbsp   col   get   array   new   bsp   add   int   

N阶二叉树:
class Tree {
        public int val;
        public List<Tree> children;

        public Tree() {
        }

        public Tree(int _val, List<Tree> _children) {
            val = _val;
            children = _children;
        }
    }


迭代法遍历:

 public List<Integer> preorder(Tree root) {
        List<Integer> list=new ArrayList<Integer>();
        if(root==null)
            return list;
        Stack<Tree> stack=new Stack<Tree>();
        stack.add(root);
        while (!stack.isEmpty()){
            Tree tree=stack.pop();
            list.add(tree.val);
            if (tree.children!=null)
            {
                int n=tree.children.size();
                for (int i=n-1;i>=0;i--){
                    stack.add(tree.children.get(i));
                }
            }
        }
        return list;
    }
}

递归法遍历:

    List<Integer> list = new ArrayList<>();

    public List<Integer> preorder(Tree root) {
        if (root == null) {
            return list;
        } else {
            list.add(root.val);
            for (int i = 0; i < root.children.size(); i++) {
                preorder(root.children.get(i));
            }
            return list;
        }
    }
}

 

589-N叉树的前序遍历

标签:ret   nbsp   col   get   array   new   bsp   add   int   

原文地址:https://www.cnblogs.com/dloading/p/10908338.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!