zoukankan      html  css  js  c++  java
  • 二叉树的前序遍历

    此博客链接:https://www.cnblogs.com/ping2yingshi/p/14085288.html

    二叉树的前序遍历

    题目链接:https://leetcode-cn.com/problems/binary-tree-preorder-traversal/

    题目

    给你二叉树的根节点 root ,返回它节点值的 前序 遍历。

    示例 1:


    输入:root = [1,null,2,3]
    输出:[1,2,3]
    示例 2:

    输入:root = []
    输出:[]
    示例 3:

    输入:root = [1]
    输出:[1]
    示例 4:


    输入:root = [1,2]
    输出:[1,2]
    示例 5:


    输入:root = [1,null,2]
    输出:[1,2]
     

    提示:

    树中节点数目在范围 [0, 100] 内
    -100 <= Node.val <= 100 

    题解

    思路1:利用递归思想

    前序遍历是先遍历根节点,然后遍历左子树,在遍历右子树,但是左子树中也可能是一个树结构,右子树中也可能是一个树结构,所以前序遍历是先遍历根节点,然后遍历左子树中的全部节点,再遍历右子树中的全部节点。可以使用递归进行前序遍历。

    方法1:

              1.定义一个函数,传入根节点和前序遍历结果,递归调用根节点的左子树,右子树。

              2.判断边界条件,当根为空,说明么有节点,返回结果。

              

    代码1

    class Solution {
        public List<Integer> preorderTraversal(TreeNode root) {
            List<Integer> list=new ArrayList<Integer>();
            Pre(root,list);
            return list;
            
        }
        public void Pre(TreeNode root,List<Integer> list){
            if(root==null)
            {
               return ;
            }
            list.add(root.val);
            if(root.left!=null){
                   Pre(root.left,list);
            }
             if(root.right!=null){
                   Pre(root.right,list);
            }
        }
    }

    结果1

    思路2:利用迭代思想

    迭代遍历树,首先需要一个栈来存储节点,先把头节点放到栈中,然后出栈,把出栈的节点右子树加入到栈中,再把节点的左子树加入到栈中。然后在出栈,只要栈不为空,就一直进行以上操作,进栈出栈。

    方法2

              1.定义一个栈,先把根节点入栈。

              2.把节点从栈中取出,加入到结果数组中。

              3.判断右子树是否为空,不为空把左子树加入栈中。

              4.判断左子树是否为空,不为空把右子树加入栈中。

    代码2

    class Solution {
        public List<Integer> preorderTraversal(TreeNode root) {
            
            List<Integer> list=new ArrayList<Integer>();
            if(root==null)
            return list;
            Stack<TreeNode> stack=new Stack();
            stack.push(root);
            while(!stack.empty()){
                TreeNode temp=stack.pop();
                list.add(temp.val);
                if(temp.right!=null){
                    stack.push(temp.right);
                }
                if(temp.left!=null){
                    stack.push(temp.left);
                }
            }
            return list;
            
        }
       
    }

    结果2

     

  • 相关阅读:
    linux基础命令1
    linux下nginx搭建
    linux 对外开放端口
    linux下mysql 登录修改密码与数据库备份
    linux下mysql部署
    linux下mysql启动 Starting MySQL. ERROR! The server quit without updating PID file(xxx/x.pid)
    aptitude软件状态标志i、v、p
    GNU各软件版本历史站点
    glibc库和glib库
    禁用ipv6的两种方法
  • 原文地址:https://www.cnblogs.com/ping2yingshi/p/14085288.html
Copyright © 2011-2022 走看看