JS實(shí)現(xiàn)二分查找的示例代碼
最近在面試的時(shí)候被問到手寫實(shí)現(xiàn)二分查找,雖然二分查找很早就聽過,也知道實(shí)現(xiàn)原理,但是手?jǐn)]起來,總是差點(diǎn)意思,正好復(fù)習(xí)一下。作為前端程序員,可能面試絕大部分公司不需要能寫很復(fù)雜的算法問題,但是這些基本的數(shù)據(jù)結(jié)構(gòu)和常見算法,還是得能手?jǐn)]出來。
什么是二分查找
二分查找是一種在有序數(shù)組中查找目標(biāo)元素的算法,它的基本思想是每次比較數(shù)組的中間元素和目標(biāo)元素,如果相等則返回中間元素的索引,如果不相等則根據(jù)比較結(jié)果縮小查找范圍,直到找到目標(biāo)元素或者查找范圍為空。二分查找的時(shí)間復(fù)雜度是O(log n),其中n是數(shù)組的長度,它比順序查找的時(shí)間復(fù)雜度O(n)要快得多。
如何實(shí)現(xiàn)二分查找
下面是用js語言實(shí)現(xiàn)二分查找的代碼示例,其中arr是有序數(shù)組,target是要查找的元素,函數(shù)返回target在arr中的索引,如果不存在則返回-1。
// 定義二分查找函數(shù) function binarySearch(arr, target) { // 定義查找范圍的左右邊界 let left = 0; let right = arr.length - 1; // 當(dāng)左邊界小于等于右邊界時(shí),繼續(xù)查找 while (left <= right) { // 計(jì)算中間元素的索引 let mid = Math.floor((left + right) / 2); // 如果中間元素等于目標(biāo)元素,返回索引 if (arr[mid] === target) { return mid; } // 如果中間元素小于目標(biāo)元素,說明目標(biāo)元素在右半部分,將左邊界移動(dòng)到中間元素的右邊 else if (arr[mid] < target) { left = mid + 1; } // 如果中間元素大于目標(biāo)元素,說明目標(biāo)元素在左半部分,將右邊界移動(dòng)到中間元素的左邊 else { right = mid - 1; } } // 如果查找范圍為空,說明目標(biāo)元素不存在,返回-1 return -1; } // 測(cè)試代碼 let arr = [1, 3, 5, 7, 9, 11, 13, 15]; // 定義一個(gè)有序數(shù)組 let target = 9; // 定義要查找的元素 let index = binarySearch(arr, target); // 調(diào)用二分查找函數(shù) console.log(index); // 輸出結(jié)果,應(yīng)該是4
二分查找的實(shí)現(xiàn)原理
- 首先,定義查找范圍的左右邊界,初始時(shí)為整個(gè)數(shù)組的范圍,即左邊界為0,右邊界為數(shù)組的長度減1。
- 然后,計(jì)算查找范圍的中間元素的索引,可以用左邊界加右邊界除以2的下取整來得到,例如,如果左邊界是0,右邊界是7,那么中間元素的索引是(0+7)/2=3.5,下取整是3。
- 接著,比較中間元素和目標(biāo)元素,如果相等,說明找到了目標(biāo)元素,返回中間元素的索引;如果不相等,說明目標(biāo)元素在中間元素的左邊或者右邊,需要縮小查找范圍。
- 如果中間元素小于目標(biāo)元素,說明目標(biāo)元素在中間元素的右邊,那么將左邊界移動(dòng)到中間元素的右邊,即左邊界等于中間元素的索引加1,右邊界不變,這樣就縮小了查找范圍的一半;如果中間元素大于目標(biāo)元素,說明目標(biāo)元素在中間元素的左邊,那么將右邊界移動(dòng)到中間元素的左邊,即右邊界等于中間元素的索引減1,左邊界不變,同樣縮小了查找范圍的一半。
- 重復(fù)第2步到第4步,直到找到目標(biāo)元素或者查找范圍為空,如果查找范圍為空,說明目標(biāo)元素不存在,返回-1。
總結(jié)
本文介紹了二分查找的定義、時(shí)間復(fù)雜度、實(shí)現(xiàn)原理和代碼示例。
二分查找是一種在有序數(shù)組中查找目標(biāo)元素的算法,它的時(shí)間復(fù)雜度是O(log n),比順序查找的時(shí)間復(fù)雜度O(n)要快得多。
二分查找的實(shí)現(xiàn)原理是每次比較數(shù)組的中間元素和目標(biāo)元素,如果相等則返回中間元素的索引,如果不相等則根據(jù)比較結(jié)果縮小查找范圍,直到找到目標(biāo)元素或者查找范圍為空。
到此這篇關(guān)于JS實(shí)現(xiàn)二分查找的示例代碼的文章就介紹到這了,更多相關(guān)JS 二分查找內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js創(chuàng)建一個(gè)input數(shù)組并綁定click事件的方法
這篇文章主要介紹了js創(chuàng)建一個(gè)input數(shù)組并綁定click事件的方法,需要的朋友可以參考下2014-06-06javascript使用閉包模擬對(duì)象的私有屬性和方法
本文給大家簡單介紹了在一個(gè)項(xiàng)目中涉及到的javascript使用閉包模擬對(duì)象的私有屬性和方法,這里記錄下來,分享給大家。2016-10-10js實(shí)現(xiàn)非常簡單的焦點(diǎn)圖切換特效實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)非常簡單的焦點(diǎn)圖切換特效,是一個(gè)非常簡單的js焦點(diǎn)圖切換效果,涉及javascript操作鼠標(biāo)事件與圖片的相關(guān)技巧,需要的朋友可以參考下2015-05-05JavaScript快速排序(quickSort)算法的實(shí)現(xiàn)方法總結(jié)
快速排序的思想式 分治法,選一個(gè)基準(zhǔn)點(diǎn),然后根據(jù)大小進(jìn)行分配,分配然完畢之后,對(duì)已經(jīng)分配的進(jìn)行遞歸操作,最終形成快速排序,所以遞歸也是快速排序思想的一個(gè)重要組成部分,本文主要給大家介紹了JavaScript實(shí)現(xiàn)快速排序的寫法,需要的朋友可以參考下2023-11-11Javascript簡單實(shí)現(xiàn)面向?qū)ο缶幊汤^承實(shí)例代碼
這篇文章主要介紹了Javascript簡單實(shí)現(xiàn)面向?qū)ο缶幊汤^承實(shí)例代碼,簡單分析了面向?qū)ο蟪绦蛟O(shè)計(jì)的特征與繼承的具體實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11js動(dòng)態(tài)添加input按鈕并給按鈕增加onclick的函數(shù)事件(帶參數(shù))完整實(shí)例
這篇文章主要介紹了js動(dòng)態(tài)添加input按鈕并給按鈕增加onclick的函數(shù)事件,結(jié)合完整實(shí)例形式分析了javascript頁面元素屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2023-07-07Bootstrap modal只加載一次數(shù)據(jù)的解決辦法(推薦)
這篇文章主要介紹了Bootstrap modal只加載一次數(shù)據(jù)的解決辦法,以及bootstrap模態(tài)框的簡單使用,需要的朋友可以參考下2017-11-11