# [Same Tree][title] ## Description Given two binary trees, write a function to check if they are the same or not. Two binary trees are considered the same if they are structurally identical and the nodes have the same value. **Example 1:** ``` Input: 1 1 / \ / \ 2 3 2 3 [1,2,3], [1,2,3] Output: true ``` **Example 2:** ``` Input: 1 1 / \ 2 2 [1,2], [1,null,2] Output: false ``` **Example 3:** ``` Input: 1 1 / \ / \ 2 1 1 2 [1,2,1], [1,1,2] Output: false ``` **Tags:** Tree, Depth-first Search ## 思路 题意是比较两棵二叉树是否相同,那么我们就深搜比较各个节点即可。 ```java /** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode(int x) { val = x; } * } */ 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.left, q.left) && isSameTree(p.right, q.right); } return false; } } ``` ## 结语 如果你同我一样热爱数据结构、算法、LeetCode,可以关注我 GitHub 上的 LeetCode 题解:[awesome-java-leetcode][ajl] [title]: https://leetcode.com/problems/same-tree [ajl]: https://github.com/Blankj/awesome-java-leetcode