阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

TypeScript获取二叉树的镜像实例详解

57次阅读
没有评论

共计 976 个字符,预计需要花费 3 分钟才能阅读完成。

导读 这篇文章主要为大家介绍了 TypeScript 获取二叉树的镜像实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
前言

给定一颗二叉树,如何获取它的镜像?本文将跟大家分享这个问题的解决方案,欢迎各位感兴趣的开发者阅读本文。

思路分析

当我们把一张写有文字的纸放在镜子前面,你看到的内容正好与你写的内容是相反的。那么我们就可以依据照镜子的经验画出它的镜像了,如下所示:

  • 镜像前后的两棵树根节点相同
  • 镜像后的树与镜像前相比:它们的左、右子节点交换了位置
  • TypeScript 获取二叉树的镜像实例详解

    通过观察后,我们就得出了一颗树的镜像过程:先序遍历这棵树的每个节点,如果遍历到的节点有子节点,就交换它的两个子节点。当交换完所有非叶节点的左、右子节点之后,就得到了树的镜像。

    对树的遍历不了解的开发者,请移步我的另一篇文章:先序遍历

    实现代码

    想清楚思路后,我们就可以很顺利的写出代码了,如下所示:

    export function MirrorImageOfTree(node: BinaryTreeNode | null): void {if (node == null) return;
      if (node.left == null && node.right == null) return;
      // 交换左右子节点
      const temp = node.left;
      node.left = node.right;
      node.right = temp;
      if (node.left) {MirrorImageOfTree(node.left);
      }
      if (node.right) {MirrorImageOfTree(node.right);
      }
    }

    完整代码请移步:MirrorImageOfTree.ts

    我们将文章开头所讲的例子代入上述代码来测试下,如下所示:

    const tree: BinaryTreeNode = {
      key: 8,
      left: {
        key: 5,
        left: {key: 3},
        right: {key: 7}
      },
      right: {key: 18, left: { key: 13}, right: {key: 22} }
    };
    MirrorImageOfTree(null);
    console.log("镜像后的树", tree);

    TypeScript 获取二叉树的镜像实例详解

    完整代码请移步:mirrorImage-test.ts

    阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

    腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

    代金券:在阿里云专用满减优惠券

    正文完
    星哥说事-微信公众号
    post-qrcode
     0
    星锅
    版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计976字。
    转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
    【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
    阿里云-最新活动爆款每日限量供应
    评论(没有评论)
    验证码
    【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中