您的位置:首页 > 编程语言 > Java开发

JAVA二叉树先序遍历递归+非递归

2016-05-15 22:31 441 查看

非递归先序遍历:

<span style="font-size:24px;">public ArrayList<Integer> preorderTraversal(TreeNode root) {
if(root==null)
return new ArrayList<Integer> ();
ArrayList<Integer> list=new ArrayList<Integer> ();
Stack<TreeNode> s=new Stack<TreeNode>();
TreeNode p=root;
while(p!=null||!s.isEmpty()){
while(p!=null){
list.add(p.val);
s.push(p);
p=p.left;
}
if(!s.isEmpty()){
p=s.pop();
p=p.right;
}
}
return list;
}</span>


递归先序遍历:

<span style="font-size:24px;">    ArrayList<Integer>list=new ArrayList<Integer>();
public ArrayList<Integer> preorderTraversal(TreeNode root){
if(root==null)
return list;
list.add(root.val);
preorderTraversal(root.left);
preorderTraversal(root.right);
return list;
}</span>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: