LeetCodeには毎日1つの質問があり、少なくなると結果は増え、量は質的変化に変化しました(最近ビジーで不定期に更新されています...)

100.同じ木

2つのバイナリツリーが与えられた場合、それらが同じかどうかをチェックする関数を記述します。
2つのツリーの構造が同じで、ノードの値が同じ場合、それらは同じと見なされます。

示例 1:
输入:       1         1
          / \       / \
         2   3     2   3

        [1,2,3],   [1,2,3]

输出: true

示例 2:
输入:      1          1
          /           \
         2             2

        [1,2],     [1,null,2]

输出: false

示例 3:
输入:       1         1
          / \       / \
         2   1     1   2

        [1,2,1],   [1,1,2]

输出: false

回答:

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public boolean isSameTree(TreeNode p, TreeNode q) {
        if(p == null && q == null) return true;
        if(p == null || q == null) return false;

        if(p.val == q.val) return isSameTree(p.right,q.right) && isSameTree(p.left,q.left);

        return false;
    }
}

59/59はテストケースに
合格ステータス:合格
実行時間:0 ms
メモリ消費:37.5 MB

このトピックは、ツリーがプライマリアルゴリズムで対称であるかどうかの判断に触発されました。その主題の判断に似ています。

おすすめ

転載: blog.csdn.net/u011148116/article/details/107862719