543. 二叉樹的直徑 golang

文章目錄

  • 543. 二叉樹的直徑
    • example
  • 正確解法
    • question
  • 代碼(wrong)

543. 二叉樹的直徑

概要: 借鑒了這個題的代碼。可是有一個測試用例過不去
https://blog.csdn.net/csdn_kou/article/details/104122067

example

給定一棵二叉樹,你需要計算它的直徑長度。一棵二叉樹的直徑長度是任意兩個結點路徑長度中的最大值。這條路徑可能穿過根結點。示例 :
給定二叉樹1/ \2   3/ \     4   5    
返回 3, 它的長度是路徑 [4,2,1,3] 或者 [5,2,1,3]。注意:兩結點之間的路徑長度是以它們之間邊的數目表示。來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/diameter-of-binary-tree
著作權歸領扣網絡所有。商業轉載請聯系官方授權,非商業轉載請注明出處。

正確解法

func diameterOfBinaryTree(root *TreeNode) int {ans := 0if nil == root {return ans}left := depthOfTree(root.Left, &ans)right := depthOfTree(root.Right, &ans)return max(ans, left + right)
}func depthOfTree(node *TreeNode, diameter *int) int {if nil == node {return 0}leftDepth := depthOfTree(node.Left, diameter)rightDepth := depthOfTree(node.Right, diameter)*diameter = max(*diameter, leftDepth+rightDepth)return max(leftDepth, rightDepth) + 1
}func max(a, b int) int {if a >= b {return a}return b
}

question

102 / 106 個通過測試用例
輸入:
[4,-7,-3,null,null,-9,-3,9,-7,-4,null,6,null,-6,-6,null,null,0,6,5,null,9,null,null,-1,-4,null,null,null,-2]
輸出:
7
預期:
8
這個測試用例的二叉樹畫出來是這個樣子
在這里插入圖片描述
去掉空,讓二叉樹更清晰
在這里插入圖片描述
為什么是八個???求解答(不看代碼,只看這個圖,按照他的說法就是7個呀???)一棵二叉樹的直徑長度是任意兩個結點路徑長度中的最大值,得出結論是從-1到-2符合條件。所以最初借用上一個的做法是不可以的!!!

代碼(wrong)

func diameterOfBinaryTree(root *TreeNode) int {if root == nil {return 0}return maxDepth(root.Left) + maxDepth(root.Right)
}func Max(TN1, TN2 int) int {if TN1 >= TN2 {return TN1 + 1} else {return TN2 + 1}}func maxDepth(root *TreeNode) int {if nil == root {return 0}return Max(maxDepth(root.Left), maxDepth(root.Right))
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/382267.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/382267.shtml
英文地址,請注明出處:http://en.pswp.cn/news/382267.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《C++ Primer 第五版》(第4.11-4.12節)——static_cast,const_cast和reinterpret_cast類型轉換, 運算符優先級表

1.static_cast,const_cast和reinterpret_cast類型轉換 static_cast:強制的類型轉換(不能用于底層的const轉換),以前C語言中的強制類型轉換都可以使用static_cast來完成。如&#xff1a;int i3; double jstatic_cast<double>(i); const_cast&#xff1a;改變底層const(指針…

《C++ Primer 第五版》(第5.1-5.6節) ——異常處理機制(try語句塊,throw表達式和catch異常捕捉處理單元)

1. 異常處理機制 C中使用try,throw和catch三個關鍵字來實現異常的觸發、拋出和處理的功能&#xff0c;具體通用語法形式如下&#xff1a; try{ if(true) normal program-statements&#xff1b;//沒有觸發異常時候執行的代碼 if(false) throw(exception); //出現錯誤&am…

《C++ Primer 第五版》(第6.1~6.3節) 函數形參和實參傳遞,可變參數列表和函數返回值

1.函數形參和實參傳遞問題 函數參數傳遞有兩種&#xff1a;值傳遞(變量&#xff0c;指針&#xff09;,引用傳遞(使用別名&#xff09;。 在形參和實參的傳遞過程中&#xff0c;牽涉到大的類類型對象、容器類型對象或者不支持拷貝操作的對象時&#xff0c;不適合采用值傳遞&…

461. 漢明距離 golang

Me 異或取出1的個數求取異或后1的個數返回 func hammingDistance(x int, y int) int {x x ^ yvar count 0for x ! 0 {x x & (x - 1)count}return count }

《C++ Primer 第五版》(第6.3~6.7節)——返回指向數組/函數的指針,函數重載,默認形參、inline函數和constexpr函數

1.返回指向數組/函數的指針 顧名思義&#xff0c;就是函數返回值為指向數組/函數的指針。 數組的性質&#xff1a;不能被拷貝&#xff0c;函數也不能返回數組。但可以返回數組指針/引用&#xff0c;聲明一個返回數組指針的函數&#xff0c;有四種方式&#xff0c;一種是直接聲明…

136. 只出現一次的數字 golang

Me 1. 先排序就好做了 執行用時 :16 ms, 在所有 Go 提交中擊敗了27.90%的用戶 內存消耗 :4.7 MB, 在所有 Go 提交中擊敗了100.00%的用戶func singleNumber(nums []int) int {sort.Ints(nums)for i:0; i < len(nums); i {if i len(nums) - 1 {return nums[i]}if nums[i] …

《C++ Primer 第五版》(第1~6章總結)

1.C采用標準庫文件iostream定義的兩個對象來實現IO機制。 2.代碼注釋應解釋關鍵數據的變量含義和代碼完成了什么功能&#xff0c;力求簡潔易懂。 3.正確理解初始化和賦值&#xff0c;聲明和定義的含義&#xff1f;初始化是在定義對象的時候同時賦值&#xff0c;賦值是定義對象…

268. 缺失數字 golang

Me 首項加末項乘以項數/2.就是總和。然后剪掉nums里面的數組和 func missingNumber(nums []int) int {var sum intlens : len(nums)for _, value : range nums {sum value}return ((1 lens) * lens) / 2 - sum }

使用touch更新文件的時間

#&#xff01;/bin/bashfunction read_dir() {for file in ls $1doif[-d $1"/"$file]thenread_dir $1"/"$fileelseecho $1"/"$filetouch $1"/"$filefidone }read_dir ./

231. 2的冪 golang

Me func isPowerOfTwo(n int) bool {return n > 0 && (n & (n-1)) 0 }

linux/windows上STM32固件燒寫工具的開發demo

1.主要實現功能&#xff1a;完成對HEX和DFU文件的燒寫&#xff0c;顯示燒寫的進度等功能 2.開發工具:Qt creator4.9.0 3.開發系統平臺&#xff1a;windows系統和linux系統兩套平臺 4.具體開發步驟&#xff1a; 1&#xff09;設計整體的界面&#xff0c;包括文件選擇界面(dfu和h…

338. 比特位計數 golang

Me func countBits(num int) []int {result : make([]int, num1)for i:0; i<num; i {result[i] numberOne(i)}return result }func numberOne(x int) int {if x 0 {return 0}var count intfor x ! 0 {x x & (x - 1)count}return count }

Qt使用qss文件管理stylesheet

內容總結簡介&#xff1a; 1&#xff09;使用.qss后綴的文件來管理Qt中每個類的具體組件的stylesheet設置。 2&#xff09;在類中使用具體.qss文件中的設置。 3&#xff09;解決控件中多個相同組件不同設置或者同一個控制不同子控制或者偽狀態的問題。 1.新建后綴名為.qss的文…

283. 移動零golang

Me 遍歷所有數組&#xff0c;統計0的個數倒著把零寫入數組末尾 func moveZeroes(nums []int) {var count, j intfor _, key : range nums {if key 0 {count} else{nums[j] keyj}}for i:len(nums) - count; i < len(nums); i {nums[i] 0} }最優解(快慢指針) 減少了數組…

QT自定義MainWindow

1.開發環境&#xff1a;Qt 4.7.3 MinGW 32bit (MSVC2015 32bit) 2.實現大綱&#xff1a; 1&#xff09;自定義邊框&#xff0c;標題欄&#xff0c;工具欄&#xff0c;內容欄&#xff0c;狀態欄&#xff08;后面三個代碼中沒有實現實現&#xff09; 2&#xff09;重寫鼠標事件…

485. 最大連續1的個數 golang

Me func findMaxConsecutiveOnes(nums []int) int {max : 0for i,j : 0, -1; i < len(nums); i {if nums[i] 0 {j i} else {if max < i -j {max i - j}}}return max }

QTextEdit實現圖片和文本同行顯示

1.開發環境&#xff1a;Qt 4.7.3 MinGW 32bit (MSVC2015 32bit) 2.實現大綱&#xff1a; 1&#xff09;實現圖片和文本在同一行顯示&#xff0c;且能夠設置字體大小和顏色 2&#xff09;能夠手動設置行的寬度和間距 3&#xff09;設置字體樣式&#xff0c;然后添加圖片&#…

3. 無重復字符的最長子串 golang

官解 func lengthOfLongestSubstring(s string) int {n : len(s)ans : 0subMap : make(map[byte]int)for i, j : 0, 0; j < n; j {if v, ok : subMap[byte(s[j])]; ok {if i < v {i v}}if ans < (j - i 1) {ans j - i 1}subMap[byte(s[j])] j 1}return ans }

QQuickWidget + QML編程實現酷炫動態動畫效果

1.具體需求&#xff1a;當Qt開發項目中需要實現簡單的動態酷炫動畫效果時&#xff0c;我們可以使用Qt中的QQuickWidget來實現&#xff0c;同時還可以使用QML編程來實現具體的動畫效果&#xff0c;具體實現的效果如下所示&#xff1a; 2.具體操作和實現效果圖&#xff1a; 1&am…

Qt中的四種信號與槽的連接方式

1. UI界面右鍵點擊控件&#xff0c;選擇“轉到槽“&#xff0c;系統會在cpp中自動添加這個組件對應的槽函數 2.在Ui界面的下面 siga如l & slot editor欄中手動添加 3.在代碼中使用connect顯示添加 4. 使用on_對象名_事件名隱式連接&#xff0c;以QPushButton為例 QPushBut…