博客
关于我
144. 二叉树的前序遍历
阅读量:798 次
发布时间:2023-04-16

本文共 1483 字,大约阅读时间需要 4 分钟。

二叉树的前序遍历问题分析及解决方案

项目场景

我们需要实现一个函数,该函数接受二叉树的根节点,并返回其节点值的前序遍历结果。

问题描述

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

原因分析

  • 递归算法的三大步骤

    • 确定递归函数的参数和返回值:函数需要处理树的根节点,并记录结果和结果的大小。
    • 确定终止条件:当根节点为空时,遍历结束。
    • 确定单层递归的逻辑:处理当前节点值,递归处理左子树,最后递归处理右子树。
  • 非递归实现:使用栈模拟递归过程,先处理根节点,处理完左子树后处理右子树。

  • 解决方案

    递归算法

    /** * Definition for a binary tree node. */struct TreeNode {    int val;    struct TreeNode *left;    struct TreeNode *right;};/** * Note: The returned array must be malloced, assume caller calls free(). */#define SIZE 2000void preorder(struct TreeNode* root, int* res, int* resSize) {    if (root == NULL) return;    res[(*resSize)++] = root->val;    preorder(root->left, res, resSize);    preorder(root->right, res, resSize);}int* preorderTraversal(struct TreeNode* root, int* returnSize) {    int* res = malloc(sizeof(int) * SIZE);    *returnSize = 0;    preorder(root, res, returnSize);    return res;}

    非递归实现

    int* preorderTraversal(struct TreeNode* root, int* returnSize) {    int* res = malloc(sizeof(int) * 2000);    *returnSize = 0;    if (root == NULL) {        return res;    }    struct TreeNode* stk[2000];    struct TreeNode* node = root;    int stk_top = 0;    while (stk_top > 0 || node != NULL) {        while (node != NULL) {            res[(*returnSize)++] = node->val;            stk[stk_top++] = node;            node = node->left;        }        node = stk[--stk_top];        node = node->right;    }    return res;}

    总结

    通过递归和非递归两种方法,我们可以高效地实现二叉树的前序遍历。递归方法直观简洁,而非递归方法在栈溢出风险较低的情况下提供了另一种实现方案。选择哪种方法取决于具体需求和性能考量。

    转载地址:http://wygfk.baihongyu.com/

    你可能感兴趣的文章
    mysql 权限整理记录
    查看>>
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>
    MYSQL 查看最大连接数和修改最大连接数
    查看>>
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>
    mysql 死锁(先delete 后insert)日志分析
    查看>>
    MySQL 死锁了,怎么办?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 添加列,修改列,删除列
    查看>>
    mysql 添加索引
    查看>>
    MySQL 添加索引,删除索引及其用法
    查看>>
    MySQL 用 limit 为什么会影响性能?
    查看>>
    MySQL 用 limit 为什么会影响性能?有什么优化方案?
    查看>>
    MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
    查看>>