题解 | #对称的二叉树#

对称的二叉树

http://www.nowcoder.com/practice/ff05d44dfdb04e1d83bdbdab320efbcb

深搜

详见代码: 对称比对!

/*
struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
    TreeNode(int x) :
            val(x), left(NULL), right(NULL) {
    }
};
*/
class Solution {
private:
    bool helper(TreeNode* pLeft, TreeNode* pRight){
        if(pLeft == NULL && pRight == NULL) return true;
        else if(pLeft == NULL || pRight == NULL) return false;
        return pLeft -> val == pRight -> val 
            && helper(pLeft -> left, pRight -> right)
            && helper(pLeft -> right, pRight -> left);
    }
public:
    bool isSymmetrical(TreeNode* pRoot) {
        if(pRoot == NULL) return true;
        return helper(pRoot -> left, pRoot -> right);
    }

};
全部评论

相关推荐

牛客5655:其他公司的面试(事)吗
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务