二叉树后序遍历

2024-08-26 0 960

145。二叉树后序遍历

难度:简单

主题: 堆栈、树、深度优先搜索、二叉树

给定二叉树的根,返回其节点值的后序遍历.

示例1:

点击下载“修复网络工具,一键解决电脑无法上网”;

二叉树后序遍历

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

示例2:

  • 输入: root = []
  • 输出: []

示例3:

  • 输入: root = [1]
  • 输出: [1]

限制:

  • 树中节点的数量在 [0, 100] 范围内。
  • -100

解决方案:

我们可以使用堆栈的迭代方法。后序遍历遵循以下顺序:左、右、根。

让我们用 php 实现这个解决方案:145。二叉树后序遍历

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

<?php // Definition for a binary tree node.

class TreeNode {

    public $val = null;

    public $left = null;

    public $right = null;

    public function __construct($val = 0, $left = null, $right = null) {

        $this->val = $val;

        $this-&gt;left = $left;

        $this-&gt;right = $right;

    }

}

/**

* @param TreeNode $root

* @return Integer[]

*/

function postorderTraversal($root) {

    ...

    ...

    ...

    /**

     * go to ./solution.php

     */

}

// Example usage:

// Example 1

$root1 = new TreeNode(1);

$root1-&gt;right = new TreeNode(2);

$root1-&gt;right-&gt;left = new TreeNode(3);

print_r(postorderTraversal($root1)); // Output: [3, 2, 1]

// Example 2

$root2 = null;

print_r(postorderTraversal($root2)); // Output: []

// Example 3

$root3 = new TreeNode(1);

print_r(postorderTraversal($root3)); // Output: [1]

?&gt;

解释:

  • treenode 类: treenode 类定义二叉树中的节点,包括其值、左子节点和右子节点。

  • postorder遍历函数:

    • 我们初始化一个空的结果数组和一个堆栈。
    • 我们使用 while 循环,只要堆栈不为空或当前节点不为空,该循环就会继续。
    • 如果当前节点不为空,我们将其压入堆栈并移动到其左子节点。
    • 如果当前节点为空,我们检查栈顶节点。如果它有一个我们还没有访问过的右孩子,我们就会移动到右孩子。否则,我们将节点的值添加到结果数组中并将其从堆栈中弹出。

这种迭代方法模拟了递归后序遍历,而不使用系统递归,从而更加节省内存

联系链接

如果您发现本系列有帮助,请考虑在 Github 上给存储库 一颗星,或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

免责声明
1. 本站所有资源来源于用户上传和网络等,如有侵权请邮件联系本站整改team@lcwl.fun!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系本站工作人员处理!
6. 本站资源售价或VIP只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 因人力时间成本问题,部分源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别!
9.本站所有源码资源都是经过本站工作人员人工亲测可搭建的,保证每个源码都可以正常搭建,但不保证源码内功能都完全可用,源码属于可复制的产品,无任何理由退款!

网站搭建学习网 PHP 二叉树后序遍历 https://www.xuezuoweb.com/14992.html

常见问题
  • 本站所有的源码都是经过平台人工部署搭建测试过可用的
查看详情
  • 购买源码资源时购买了带主机的套餐是指可以享受源码和所选套餐型号的主机两个产品,在本站套餐里开通主机可享优惠,最高免费使用主机
查看详情

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务

Fa快捷助手
手机编程软件开发

在手机上用手点一点就能轻松做软件

去做软件
链未云主机
免备案香港云主机

开通主机就送域名的免备案香港云主机

去使用
链未云服务器
免备案香港云服务器

支持售后、超低价、稳定的免备案香港云服务器

去使用