Leetcode 같은 나무 (100) 문제 해결 방안 및 C ++에서 구현

면책 조항 :이 문서는 블로거 원본입니다은 허용 블로거없이 복제 할 수 없다. https://blog.csdn.net/gjh13/article/details/90737664

문제 해결 아이디어 :

이 질문 방법은 재귀 사용합니다.

  1. 현재 노드 p와 q 이전에는, true를 돌려 두 경우는 null, null 이외의 결정;

  2. a가 null의 경우, 다른 비 - 널 (null)은 다음 false를 반환;

  3. PQ는 null이 아닌, 그들의 발을 비교, 발 동일하지 않을 경우, 거짓;

  4. 재귀 좌우 자식 노드가 동일한 결정 계산해 동일한 경우.

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

 

 

추천

출처blog.csdn.net/gjh13/article/details/90737664