给你一个二叉树的根节点 root ,请你将此二叉树上下翻转,并返回新的根节点
你可以按下面的步骤翻转一棵二叉树:
原来的左子节点变成新的根节点
原来的根节点变成新的右子节点
原来的右子节点变成新的左子节点
上面的步骤逐层进行。题目数据保证每个右节点都有一个同级节点(即共享同一父节点的左节点)且不存在子节点
示例 1:
输入:root = [1,2,3,4,5]
输出:[4,5,2,null,null,3,1]
示例 2:
输入:root = []
输出:[]
示例 3:
输入:root = [1]
输出:[1]
思路:依次交换左 有 根节点 最后返回交过后的根节点即可解决问题
代码
struct TreeNode* upsideDownBinaryTree(struct TreeNode* root){
if(root==NULL)
{
return 0;
}
struct TreeNode*parent=NULL;
struct TreeNode*parent_left=NULL;
struct TreeNode*parent_right=NULL;
while(root!=NULL)
{
parent_left=root->left;
root->left=parent_right;
parent_right=root->right;
root->right=parent;
parent=root;
root=parent_left;
}
return parent;
}