許多二分查找實作中的一個問題?
Sep 10, 2023 pm 04:21 PM我們知道二分搜尋演算法比線性搜尋演算法更好。此演算法執行所需的時間為O(log n)。儘管大多數情況下,實現的程式碼存在一些問題。讓我們來考慮一個二分搜尋演算法函數,如下所示 −
範例
1 2 3 4 5 6 7 8 9 10 11 |
|
這個演算法在開始和結束達到一個較大的數之前都能正常運作。如果 (開始 結束) 超過了 232 - 1 的值,那麼在包裝後可能會傳回一個負數。由於負數不支援作為數組索引,所以可能會引起一些問題。
為了解決這個問題,有幾種不同的方法。
方法1
1 |
|
第二種方法只適用於Java,因為C或C 沒有>>>運算子。
方法2(只適用於Java)
1 |
|
由於C或C 不支援>>>,我們可以使用下列方法。
方法3
1 |
|
以上是許多二分查找實作中的一個問題?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱門文章

熱門文章

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)