题解 | #对称的二叉树#

对称的二叉树

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 {
public:
    //左子树根左右,右子树根右左
    //增加不存在的值为虚结点
    int temp = 1010;
    vector<int> vl, vr;
    bool flag = true;
    void Ltraverse(TreeNode* pRoot)
    {
        if(pRoot == NULL) return;
        vl.push_back(pRoot->val);
        if(pRoot->left!=NULL){
            Ltraverse(pRoot->left);
        }else{
            vl.push_back(temp);
        }
        if(pRoot->right!=NULL){
            Ltraverse(pRoot->right);
        }else{
            vl.push_back(temp);
        }
    }
    void Rtraverse(TreeNode* pRoot)
    {
        if(pRoot == NULL) return;
        vr.push_back(pRoot->val);
        if(pRoot->right!=NULL){
            Rtraverse(pRoot->right);
        }else{
            vr.push_back(temp);
        }
        if(pRoot->left!=NULL){
            Rtraverse(pRoot->left);
        }else{
            vr.push_back(temp);
        }
    }
    bool isSymmetrical(TreeNode* pRoot) {
        if(pRoot == NULL) return true;
        Ltraverse(pRoot->left);
        Rtraverse(pRoot->right);
        if(vl.size() != vr.size())
            return false;
        for(int i = 0; i < vl.size(); i++)
        {
            if(vl[i] != vr[i])
            {
                flag = false;
                break;
            }
        }
        return flag;
    }
};
全部评论

相关推荐

TP-LINK 前端工程师 年包大概20出头 本科
点赞 评论 收藏
转发
点赞 评论 收藏
转发
点赞 收藏 评论
分享
牛客网
牛客企业服务