摘要:遞歸法復(fù)雜度時間空間遞歸??臻g思路如果兩個根節(jié)點一個為空,一個不為空,或者兩個根節(jié)點值不同,說明出現(xiàn)了不一樣的地方,返回假。代碼遞歸法復(fù)雜度時間空間遞歸??臻g思路其實和寫法是一樣的,是比較兩個節(jié)點的兩個左邊,然后再比較兩個節(jié)點的兩個右邊。
Same Tree
Given two binary trees, write a function to check if they are equal or not.遞歸法 復(fù)雜度Two binary trees are considered equal if they are structurally identical and the nodes have the same value.
時間 O(N) 空間 O(h) 遞歸??臻g
思路如果兩個根節(jié)點一個為空,一個不為空,或者兩個根節(jié)點值不同,說明出現(xiàn)了不一樣的地方,返回假。如果兩個節(jié)點都是空,則是一樣的,返回真。然后我們再遞歸它們的左右節(jié)點,如果遞歸結(jié)果中一個或兩個是假,就返回假。否則,說明左右子樹都是完全一樣的。
代碼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
遞歸法 復(fù)雜度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) 遞歸??臻g
思路其實和Same Tree寫法是一樣的,Same Tree是比較兩個節(jié)點的兩個左邊,然后再比較兩個節(jié)點的兩個右邊。而對稱樹是要判斷左節(jié)點的左節(jié)點和右節(jié)點的右節(jié)點相同(外側(cè)),左節(jié)點的右節(jié)點和右節(jié)點的左節(jié)點相同(內(nèi)側(cè))。不過對稱樹是判斷一棵樹,我們要用Same Tree一樣的寫法,就要另寫一個可以比較兩個節(jié)點的函數(shù)。
注意,Leetcode中當(dāng)根節(jié)點為空時,樹也是對稱的
代碼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)迭代法 復(fù)雜度
時間 O(N) 空間 O(h)
思路因為該題本質(zhì)就是二叉樹遍歷,所以我們也可以用迭代來解。這里用一個隊列,兩棵樹按照對稱的順序加入節(jié)點,然后進行比較。
代碼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
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/64541.html
摘要:解題思路所謂的對稱,是左右相反位置的節(jié)點的值判斷是否相同。只要出現(xiàn)不同,即可返回即可,否則繼續(xù)進行處理。 topic: 101. Symmetric Tree Description: Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center). For...
摘要:在線網(wǎng)站地址我的微信公眾號完整題目列表從年月日起,每天更新一題,順序從易到難,目前已更新個題。這是項目地址歡迎一起交流學(xué)習(xí)。 這篇文章記錄我練習(xí)的 LeetCode 題目,語言 JavaScript。 在線網(wǎng)站:https://cattle.w3fun.com GitHub 地址:https://github.com/swpuLeo/ca...我的微信公眾號: showImg(htt...
摘要:微信公眾號記錄截圖記錄截圖目前關(guān)于這塊算法與數(shù)據(jù)結(jié)構(gòu)的安排前。已攻略返回目錄目前已攻略篇文章。會根據(jù)題解以及留言內(nèi)容,進行補充,并添加上提供題解的小伙伴的昵稱和地址。本許可協(xié)議授權(quán)之外的使用權(quán)限可以從處獲得。 Create by jsliang on 2019-07-15 11:54:45 Recently revised in 2019-07-15 15:25:25 一 目錄 不...
閱讀 2920·2021-11-19 09:40
閱讀 3604·2021-10-09 09:43
閱讀 2687·2021-09-22 15:31
閱讀 1739·2021-07-30 15:31
閱讀 791·2019-08-30 15:55
閱讀 3270·2019-08-30 15:54
閱讀 1172·2019-08-30 11:26
閱讀 1920·2019-08-29 13:00