目錄
範例
方法3
方法2(只適用於Java)
首頁 後端開發 C++ 許多二分查找實作中的一個問題?

許多二分查找實作中的一個問題?

Sep 10, 2023 pm 04:21 PM
實現(implementation) 二分查找(binary search) 問題(problem)

許多二分查找實作中的一個問題?

我們知道二分搜尋演算法比線性搜尋演算法更好。此演算法執行所需的時間為O(log n)。儘管大多數情況下,實現的程式碼存在一些問題。讓我們來考慮一個二分搜尋演算法函數,如下所示 −

範例

1

2

3

4

5

6

7

8

9

10

11

int binarySearch(int array[], int start, int end, int key){

   if(start <= end){

      int mid = (start + end) /2); //mid location of the list

      if(array[mid] == key)

         return mid;

      if(array[mid] > key)

         return binarySearch(array, start, mid-1, key);

         return binarySearch(array, mid+1, end, key);

   }

   return -1;

}

登入後複製

這個演算法在開始和結束達到一個較大的數之前都能正常運作。如果 (開始 結束) 超過了 232 - 1 的值,那麼在包裝後可能會傳回一個負數。由於負數不支援作為數組索引,所以可能會引起一些問題。

為了解決這個問題,有幾種不同的方法。

方法1

1

int mid = start + ((end - start) / 2)

登入後複製

第二種方法只適用於Java,因為C或C 沒有>>>運算子。

方法2(只適用於Java)

1

int mid = (start + end) >>> 1

登入後複製

由於C或C 不支援>>>,我們可以使用下列方法。

方法3

1

int mid = ((unsigned int) low + (unsigned int) high) >> 1

登入後複製
#

以上是許多二分查找實作中的一個問題?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

c語言函數返回值的類型有哪些?返回值是由什麼決定的? c語言函數返回值的類型有哪些?返回值是由什麼決定的? Mar 03, 2025 pm 05:52 PM

c語言函數返回值的類型有哪些?返回值是由什麼決定的?

Gulc:從頭開始建造的C庫 Gulc:從頭開始建造的C庫 Mar 03, 2025 pm 05:46 PM

Gulc:從頭開始建造的C庫

c語言函數的定義和調用規則是什麼 c語言函數的定義和調用規則是什麼 Mar 03, 2025 pm 05:53 PM

c語言函數的定義和調用規則是什麼

c語言函數格式字母大小寫轉換步驟 c語言函數格式字母大小寫轉換步驟 Mar 03, 2025 pm 05:53 PM

c語言函數格式字母大小寫轉換步驟

c語言函數返回值在內存保存在哪裡? c語言函數返回值在內存保存在哪裡? Mar 03, 2025 pm 05:51 PM

c語言函數返回值在內存保存在哪裡?

distinct用法和短語分享 distinct用法和短語分享 Mar 03, 2025 pm 05:51 PM

distinct用法和短語分享

如何有效地使用STL(排序,查找,轉換等)的算法? 如何有效地使用STL(排序,查找,轉換等)的算法? Mar 12, 2025 pm 04:52 PM

如何有效地使用STL(排序,查找,轉換等)的算法?

C標準模板庫(STL)如何工作? C標準模板庫(STL)如何工作? Mar 12, 2025 pm 04:50 PM

C標準模板庫(STL)如何工作?

See all articles