摘要:遞歸法復雜度時間空間遞歸棧空間思路如果兩個根節點一個為空,一個不為空,或者兩個根節點值不同,說明出現了不一樣的地方,返回假。代碼遞歸法復雜度時間空間遞歸棧空間思路其實和寫法是一樣的,是比較兩個節點的兩個左邊,然后再比較兩個節點的兩個右邊。
Same Tree
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.
時間 O(N) 空間 O(h) 遞歸棧空間
思路如果兩個根節點一個為空,一個不為空,或者兩個根節點值不同,說明出現了不一樣的地方,返回假。如果兩個節點都是空,則是一樣的,返回真。然后我們再遞歸它們的左右節點,如果遞歸結果中一個或兩個是假,就返回假。否則,說明左右子樹都是完全一樣的。
代碼public class Solution { public boolean isSameTree(TreeNode p, TreeNode q) { if(p == null && q == null) return true; if(p == null || q == null || p.val != q.val) return false; return isSameTree(p.left, q.left) && isSameTree(p.right, q.right); } }
2018/2
class Solution: def isSameTree(self, p, q): """ :type p: TreeNode :type q: TreeNode :rtype: bool """ if p is None and q is None: return True if p is None or q is None: return False return p.val == q.val and self.isSameTree(p.left, q.left) and self.isSameTree(p.right, q.right)
2018/10
func isSameTree(p *TreeNode, q *TreeNode) bool { if p == nil && q == nil { return true } if p != nil && q != nil { return p.Val == q.Val && isSameTree(p.Left, q.Left) && isSameTree(p.Right, q.Right) } return false }Symmetric Tree
遞歸法 復雜度Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center).
For example, this binary tree is symmetric:
1 / 2 2 / / 3 4 4 3But the following is not:
1 / 2 2 3 3
時間 O(N) 空間 O(h) 遞歸棧空間
思路其實和Same Tree寫法是一樣的,Same Tree是比較兩個節點的兩個左邊,然后再比較兩個節點的兩個右邊。而對稱樹是要判斷左節點的左節點和右節點的右節點相同(外側),左節點的右節點和右節點的左節點相同(內側)。不過對稱樹是判斷一棵樹,我們要用Same Tree一樣的寫法,就要另寫一個可以比較兩個節點的函數。
注意,Leetcode中當根節點為空時,樹也是對稱的
代碼public class Solution { public boolean isSymmetric(TreeNode root) { return root == null ? true : helper(root.left, root.right); } private boolean helper(TreeNode node1, TreeNode node2){ if(node1 == null && node2 == null){ return true; } if(node1 == null || node2 == null || node1.val != node2.val){ return false; } return helper(node1.left, node2.right) && helper(node1.right, node2.left); } }
2018/2
class Solution: def isSymmetric(self, root): """ :type root: TreeNode :rtype: bool """ return root is None or self.helper(root.left, root.right) def helper(self, node1, node2): if node1 is None and node2 is None: return True if node1 is None or node2 is None: return False return node1.val == node2.val and self.helper(node1.right, node2.left) and self.helper(node1.left, node2.right)迭代法 復雜度
時間 O(N) 空間 O(h)
思路因為該題本質就是二叉樹遍歷,所以我們也可以用迭代來解。這里用一個隊列,兩棵樹按照對稱的順序加入節點,然后進行比較。
代碼public class Solution { public boolean isSymmetric(TreeNode root) { if(root == null) return true; Queuequeue1 = new LinkedList (); Queue queue2 = new LinkedList (); queue1.offer(root.left); queue2.offer(root.right); while(!queue1.isEmpty() && !queue2.isEmpty()){ TreeNode node1 = queue1.poll(); TreeNode node2 = queue2.poll(); // 如果都是null,說明是相同的 if(node1 == null && node2 == null){ continue; } // 如果有一個是null,或者值不同,則有問題 if(node1 == null || node2 == null || node1.val != node2.val){ return false; } queue1.offer(node1.left); queue2.offer(node2.right); queue1.offer(node1.right); queue2.offer(node2.left); } return queue1.isEmpty() && queue2.isEmpty(); } }
2018/2
from collections import deque class Solution: def isSymmetric(self, root): """ :type root: TreeNode :rtype: bool """ if root is None: return True queue1 = deque() queue2 = deque() queue1.append(root.left) queue2.append(root.right) while queue1 and queue2: node1 = queue1.popleft() node2 = queue2.popleft() if node1 is None and node2 is None: continue if node1 is None or node2 is None: return False if node1.val != node2.val: return False queue1.append(node1.left) queue2.append(node2.right) queue1.append(node1.right) queue2.append(node2.left) return True
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/64541.html
摘要:解題思路所謂的對稱,是左右相反位置的節點的值判斷是否相同。只要出現不同,即可返回即可,否則繼續進行處理。 topic: 101. Symmetric Tree Description: Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center). For...
摘要:在線網站地址我的微信公眾號完整題目列表從年月日起,每天更新一題,順序從易到難,目前已更新個題。這是項目地址歡迎一起交流學習。 這篇文章記錄我練習的 LeetCode 題目,語言 JavaScript。 在線網站:https://cattle.w3fun.com GitHub 地址:https://github.com/swpuLeo/ca...我的微信公眾號: showImg(htt...
摘要:微信公眾號記錄截圖記錄截圖目前關于這塊算法與數據結構的安排前。已攻略返回目錄目前已攻略篇文章。會根據題解以及留言內容,進行補充,并添加上提供題解的小伙伴的昵稱和地址。本許可協議授權之外的使用權限可以從處獲得。 Create by jsliang on 2019-07-15 11:54:45 Recently revised in 2019-07-15 15:25:25 一 目錄 不...
閱讀 2917·2021-11-19 09:40
閱讀 3602·2021-10-09 09:43
閱讀 2683·2021-09-22 15:31
閱讀 1736·2021-07-30 15:31
閱讀 790·2019-08-30 15:55
閱讀 3268·2019-08-30 15:54
閱讀 1170·2019-08-30 11:26
閱讀 1918·2019-08-29 13:00