C++二叉树的镜像(数据结构-树)

操作给定的二叉树,将其变换为源二叉树的镜像。 数据范围:二叉树的节点数 0≤n≤1000 , 二叉树每个节点的…

操作给定的二叉树,将其变换为源二叉树的镜像。

数据范围:二叉树的节点数 0≤n≤1000 , 二叉树每个节点的值0≤val≤1000

要求: 空间复杂度 O(n) 。本题也有原地操作,即空间复杂度 O(1) 的解法,时间复杂度 O(n)

比如:

源二叉树

镜像二叉树

示例:
输入:

{8,6,10,5,7,9,11}
返回值:

{8,10,6,11,9,7,5}

本题考察数据结构树的使用,可用递归来解。两种解法:一种是自上而下,从根结点开始,直接交换左右子树结点,再分别对它们的左右子树进行处理,一直到最深层完成;另一种是自下而上,探索到最深层后,左右子树互换,再返回到上一层,进行左右互换,依次类推,到返回至根结点时,对根结点的左右子树进行互换,此时完成递归。

解法一:自上而下

解法二:自下而上

本文来自网络,不代表软粉网立场,转载请注明出处:https://www.rfff.net/p/8105.html

作者: HUI

发表评论

您的电子邮箱地址不会被公开。

返回顶部