
class Solution {
public:
bool isSymmetric(TreeNode* root) {
if(!root) return true;
return dfs(root->left,root->right);
}
bool dfs(TreeNode* t1,TreeNode* t2)
{
if(!t1||!t2) return !t1&&!t2; //只有两个节点同时为空 返回true
if(t1->val!=t2->val) return false;
return dfs(t1->left,t2->right)&&dfs(t1->right,t2->left);
}
}
对称二叉树判断算法
本文介绍了一种用于判断二叉树是否对称的有效算法。通过对二叉树的左右子树进行深度优先搜索(DFS),该算法能够递归地比较对应节点的值,从而确定整棵树是否关于根节点对称。核心思想在于检查每个节点的左子树是否为右子树的镜像。
1312

被折叠的 条评论
为什么被折叠?



