LintCode - 469.等价二叉树

来源:互联网 发布:typedef struct 数组 编辑:程序博客网 时间:2024/05/21 01:30


检查两棵二叉树是否等价。等价的意思是说,首先两棵二叉树必须拥有相同的结构,并且每个对应位置上的节点上的数都相等。

样例
    1             1   / \           / \  2   2   and   2   2 /             /4             4

就是两棵等价的二叉树。

    1             1   / \           / \  2   3   and   2   3 /               \4                 4

就不是等价的。


使用递归,如果当前两个结点都是NULL,返回true。如果有一个是NULL,则返回false。如果当前两个结点key相等,再递归进行判断。


/** * Definition of TreeNode: * class TreeNode { * public: *     int val; *     TreeNode *left, *right; *     TreeNode(int val) { *         this->val = val; *         this->left = this->right = NULL; *     } * } */class Solution {public:    /**     * @aaram a, b, the root of binary trees.     * @return true if they are identical, or false.     */    bool isIdentical(TreeNode* a, TreeNode* b) {        // Write your code here        if( a == NULL && b == NULL ) return true;        if( a == NULL || b == NULL ) return false;        if( a->val != b->val ) return false;        return ( isIdentical( a->left, b->left ) && isIdentical( a->right, b->right ) );    }};


0 0
原创粉丝点击