码迷,mamicode.com
首页 > 其他好文 > 详细

100.Same Tree

时间:2017-09-17 21:00:08      阅读:101      评论:0      收藏:0      [点我收藏+]

标签:class   amp   利用   close   nbsp   层序遍历   https   closed   leetcode   

题目链接https://leetcode.com/problems/same-tree/description/

题目大意:给出两棵二叉树,判断这两颗二叉树是否完全相同。(不知道是不是这个题后台崩了,一直ca, 但我觉得我的方法是没问题的,类似于101题)

法一:利用递归直接判断是否相同,若两个结点都为null,则返回true;若一个结点为null,则返回false;否则判断值是否相等,以及其左右子树是否相同,代码如下:

技术分享
 1     private static boolean isSameTree(TreeNode p, TreeNode q) {
 2         if(p == null && q == null) {
 3             return true;
 4         }
 5         if(p == null || q == null) {
 6             return false;
 7         }
 8         else {
 9             if(p.val != q.val) {
10                 return false;
11             }
12             else {
13                 return isSameTree(p.left, q.left) && isSameTree(p.right, q.right);
14             }
15         }
16     }
View Code

法二:利用层序遍历,两个队列分别遍历两颗树,将每个结点都放进队列中(无论是否为null),然后再依次进行判断,代码如下:

技术分享
 1     private static boolean isSameTree1(TreeNode p, TreeNode q) {
 2         Queue<TreeNode> queueP = new LinkedList<TreeNode>();
 3         Queue<TreeNode> queueQ = new LinkedList<TreeNode>();
 4         queueP.offer(p);
 5         queueQ.offer(q);
 6         boolean flag = true;
 7         while(!queueP.isEmpty() && !queueQ.isEmpty()) {
 8             TreeNode nodeP = queueP.poll();
 9             TreeNode nodeQ = queueQ.poll();
10             if((nodeP == null && nodeQ != null) || (nodeP != null && nodeQ == null)) {
11                 return false;
12             }
13             else if(nodeP != null && nodeQ != null) {
14                 if(nodeP.val != nodeQ.val) {
15                     return false;
16                 }
17                 else {
18                     queueP.offer(nodeP.left);
19                     queueP.offer(nodeP.right);
20                     queueP.offer(nodeQ.left);
21                     queueP.offer(nodeQ.right);
22                 }
23             }
24         }
25         if(!queueP.isEmpty() || !queueQ.isEmpty()) {
26             return false;
27         }
28         return flag;
29     }
View Code

 

100.Same Tree

标签:class   amp   利用   close   nbsp   层序遍历   https   closed   leetcode   

原文地址:http://www.cnblogs.com/cing/p/7536853.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!