题目链接
题目描述:
给定一个二叉树,检查它是否是镜像对称的。
例如,二叉树 [1,2,2,3,4,4,3] 是对称的。
解题思路&代码
递归
- 题意是要求判断对称树,本质上来说还是判断两个树的关系。然主函数只给了一个参数root,所以可以考虑添加辅助函数增加参数列表
- 确定两个递归终止条件:一、显然两结点同时为空,那么肯定是相同了;二、如果在两结点中,一个为空,另一个不为空,显然不相同。注意:代码顺序不要改变,因为情况1用到的逻辑运算符为
&&
,情况2用到的逻辑运算符为||
,显然2在1之前会涵盖1的情况。其实,本质上来说,情况2属于异或 - 剩下的代码本质上来说就是先序遍历的递归框架
代码
class Solution {
public:
bool isSymmetric(TreeNode* root) {
return helper(root, root);
}
bool helper(TreeNode* node1, TreeNode* node2){
if(!node1 && !node2)
return true;
if(!node1 || !node2)
return false;
if(node1->val != node2->val)
return false;
return helper(node1->left, node2->right) && helper(node1->right, node2->left);
}
};
迭代
本文以队列举例(栈也可以)。
根据上面递归的过程,本质上来说我们还是用两个树作对比判断是否对称。于是我们可以利用队列的特点(先进先出),一次出队两个结点,然后作比较。此过程类似于BFS。
我们需要关注的是在两个结点的过程中发生了什么,其他的交给循环迭代。那么在这个过程中发生了什么?
- 从队列中取出两个结点并将两结点出队
- 对照递归的两个终止条件(
同为空
或者异或
) - 判断两个值是否相等。如果是对称的,队列中每两个结点应该是连续相等的。
- 之后就是进队操作。按两个结点的左右子结点相反的顺序入队。
代码
class Solution {
public:
bool isSymmetric(TreeNode* root) {
if(!root)
return true;
queue<TreeNode*> record;
record.push(root->left);
record.push(root->right);
while(!record.empty()){
TreeNode* node1 = record.front();
record.pop();
TreeNode* node2 = record.front();
record.pop();
if(!node1 && !node2)
continue;
if(!node1 || !node2)
return false;
if(node1->val != node2->val)
return false;
record.push(node1->left);
record.push(node2->right);
record.push(node1->right);
record.push(node2->left);
}
return true;
}
};
如果有错误或者不严谨的地方,请务必给予指正,十分感谢。