演算法學習 - Linear Search 及 Binary Search 介紹
最近在補資料結構與演算法,雖然實際在前端的工作中還沒有碰到需要使用演算法的地方,但學習資料結構與演算法,可以提升程式能力,也能為將來面試做準備。
這篇會從基礎的 Linear Search 和 Binary Search 介紹起,let’s go~~
Linear Search
顧名思義是「漸進式搜尋」,也就是一個一個找,透過檢查 array 中所有元素,尋找符合條件的元素。
停止條件:
- 找到相符元素
- 未找到,回傳
-1
Big O notation
- best:
O(1)
- worst:
O(n)
- 需要 loop 完整個 array
- average:
O(n/2)
Binary Search
先跟中間值比較,若大於/小於,再與大於/小於那一半的中間值比較,重複以上動作直到找到搜尋值。
- 優勢:相較於 linear search 會快很多
- 限制:僅能使用於 sorted array
範例程式碼,尋找符合條件的數字:
1 | function(arr: number[], target: number) { |
Big O notation:
- best:
O(1)
- worst:
O(logn)
- 每次尋找都會將 array 切半尋找,若 length = 8,則過程為
8 -> 4 -> 2 -> 1
,歷經 3 步,也就是 ,因此可以類推演算法所需步數為 ,O natation 為O(logn)
- 每次尋找都會將 array 切半尋找,若 length = 8,則過程為
- average:
O(logn)
- 標題: 演算法學習 - Linear Search 及 Binary Search 介紹
- 作者: 時雨 Justin
- 撰寫于 : 2024-12-02 12:46:05
- 更新于 : 2024-12-02 12:46:05
- 連結: https://www.frontendnote.site/frontend/linear-search-and-binary-search-intro/
- 版權宣告: 本作品采用 CC BY-NC-SA 4.0 进行许可。
留言