剑指offer树27.二叉树的镜像
Posted trevo
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指offer树27.二叉树的镜像相关的知识,希望对你有一定的参考价值。
二叉树的镜像
递归法
递归的先序遍历二叉树,交换每个节点的左右子节点,即可生成二叉树的镜像
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
TreeNode* mirrorTree(TreeNode* root) {
if(root == nullptr) return nullptr;
TreeNode *tmp = root->left;
root->left = mirrorTree(root->right);
root->right = mirrorTree(tmp);
return root;
}
};
辅助栈/队列
利用栈或队列遍历树的所有节点,交换每个节点的左右子节点
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
TreeNode* mirrorTree(TreeNode* root) {
stack<TreeNode*> s;
s.push(root);
while (!s.empty()) {
TreeNode* node = s.top();
s.pop();
if (node == NULL) {
continue;
}
swap(node->left, node->right);
s.push(node->left);
s.push(node->right);
}
return root;
}
};
class Solution {
public:
TreeNode* mirrorTree(TreeNode* root) {
queue<TreeNode*> q;
q.push(root);
while (!q.empty()) {
TreeNode* node = q.front();
q.pop();
if (node == NULL) {
continue;
}
swap(node->left, node->right);
q.push(node->left);
q.push(node->right);
}
return root;
}
};
以上是关于剑指offer树27.二叉树的镜像的主要内容,如果未能解决你的问题,请参考以下文章
剑指offer(C++)-JZ27:二叉树的镜像(数据结构-树)
剑指offer(C++)-JZ27:二叉树的镜像(数据结构-树)
剑指 Offer 26. 树的子结构 / 剑指 Offer 27. 二叉树的镜像 / 剑指 Offer 28. 对称的二叉树 / 剑指 Offer 29. 顺时针打印矩阵