[DSA] 二元搜尋(Binary Search)

**二元搜尋(Binary Search)**是一種在有序序列中查找特定元素的算法。這種搜索方法的效率非常高,比起使用線性搜索,在大型數據集中通常能夠大大減少所需的搜尋步驟。


以下是二元搜尋的基本步驟:


1. **初始化**:選取序列的中點作為當前的元素。

   

2. **比較**:將該元素與所尋找的元素進行比較。


3. **決策**:

   - 如果中點的元素**等於**所尋找的元素,則搜索成功,返回該位置。

   - 如果所尋找的元素**小於**中點的元素,則在當前中點**之前**的子序列中繼續進行二元搜尋。

   - 如果所尋找的元素**大於**中點的元素,則在當前中點**之後**的子序列中繼續進行二元搜尋。


4. **重複**:不斷地縮小搜尋範圍,直到找到該元素或範圍縮小到0。


這個方法的關鍵在於,每一次比較都使得搜索範圍減半,從而大大加快了搜索速度。


**時間複雜度**:  

由於每次操作都會使搜索範圍減少一半,所以二元搜尋的時間複雜度是O(log n),其中n是序列的大小。這使得二元搜尋比線性搜尋(其時間複雜度為O(n))要快得多,特別是對於大型數據集。


**注意**:  

要使用二元搜尋,前提是序列必須是有序的。如果數據不是有序的,那麼在使用二元搜尋之前,必須先對它進行排序。


總之,二元搜尋是一種高效的查找方法,適用於有序的數據集,特別是當數據集非常大時。


其他程式面試/Leetcode相關討論:

留言

Google Search

推薦內容橫式

本月熱門文章

綠能貪污原來大多是國民黨民眾代表

國民黨李煥家族 李慶中李慶珠甲等特考舞弊 李慶華詐領助理補助款 李慶安雙重國籍

中國新病毒 HMPV 人類偏肺病毒 要戴口罩 勤洗手

八炯統戰影片心得 千萬要謹慎 勿掉入金錢陷阱

國防安全:中華人民共和國吸收中華民國高階軍官作為內應

2024年5月至12月台中市非自然死亡列表 從南寧, KK .. 到台中西屯?

立法院過去幾週都被國民黨及黃國昌挾持 無法討論法案 還要直接一路通過

讓你懷疑自已的記憶力以及語文能力的經典討論串:無心插柳柳橙汁

統戰影片心得 舔共台灣人做的是會得罪雙方人民的事情

柯文哲:當選後將改掉黑金槍毒不得參選」排黑條款。 台灣民眾黨有哪些人受影響

這個網誌中的熱門文章

Android應用開發豆知識:利用 adb 安裝 apk 到裝置上

Android 中文輸入法 官方版 ! Gboard - Google 鍵盤 開始支援注音輸入啦

Google Play 推薦Android app 誠徵App排行榜

北京故宮首訪,一窺清宮秘史 大玉兒 & 甄嬛

[家教][社會觀察] 建中教我的事 沒上建中被父母親折磨? 在建中到底是如何 ...

[FAANG面試] Amazon/AWS 領導力準則 14 Amazon Leadership Principles

Acer ICONIA Smart S300 更新後越來越好 Acer也有出手機?!

[品質控制] 什麼是Sanity test ? 軟體測試常見名詞整理 包含不同部門的測試人員負責範圍

新鮮人找工作:職場名詞解釋 AE FAE Pre-sales Post-sales