您好,欢迎来到爱问旅游网。
搜索
您的当前位置:首页LeetCode每日一题题解:144. 二叉树的前序遍历-题解-python && C++源代码

LeetCode每日一题题解:144. 二叉树的前序遍历-题解-python && C++源代码

来源:爱问旅游网

难度简单752收藏分享切换为英文接收动态反馈

给你二叉树的根节点 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

题目思路:我们从根节点开始,先访问当前节点,然后再访问当前节点的下一个节点的左节点,然后再右节点,不停的进行递归

Python代码:

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def preorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        ans = []
        def dfs (Node: Optional[TreeNode]):
            if Node is None:
                return 
            ans.append(Node.val)
            dfs(Node.left)
            dfs(Node.right)
        dfs(root)
        return ans

C++代码:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    vector<int> preorderTraversal(TreeNode* root) {
        vector<int> ans;
        dfs(root , ans);
        return ans;
    }
    void dfs(TreeNode *Node , vector<int> &ans)//定义一个函数,用来递归处理
    { 
        if (Node == nullptr){   //如果节点为空,则直接输出结果
            return ;
        }
        ans.push_back(Node->val);  //将节点的值加入列表
        dfs(Node->left , ans);    //节点左边的值进行递归
        dfs(Node->right , ans); //节点右边的值进行递归
    }

};

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- awee.cn 版权所有 湘ICP备2023022495号-5

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务