100. Same Tree

1.描述

Given two binary trees, write a function to check if they are equal or not.

Two binary trees are considered equal if they are structurally identical and the nodes have the same value.

2.分析

3.代码

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */
bool isSameTree(struct TreeNode* p, struct TreeNode* q) {
    if (NULL == p && NULL == q) return true;
    if (NULL == p || NULL == q) return false;
    if (p->val != q->val) return false;
    
    bool left  = isSameTree(p->left, q->left);
    bool right = isSameTree(p->right, q->right);
    
    return left && right ? true : false;
}

你可能感兴趣的:(100. Same Tree)