C語(yǔ)言二分查找算法及實(shí)現(xiàn)代碼
二分査找也稱(chēng)折半査找,其優(yōu)點(diǎn)是查找速度快,缺點(diǎn)是要求所要査找的數(shù)據(jù)必須是有序序列。該算法的基本思想是將所要査找的序列的中間位置的數(shù)據(jù)與所要査找的元素進(jìn)行比較,如果相等,則表示査找成功,否則將以該位置為基準(zhǔn)將所要査找的序列分為左右兩部分。接下來(lái)根據(jù)所要査找序列的升降序規(guī)律及中間元素與所查找元素的大小關(guān)系,來(lái)選擇所要査找元素可能存在的那部分序列,對(duì)其采用同樣的方法進(jìn)行査找,直至能夠確定所要查找的元素是否存在,具體的使用方法可通過(guò)下面的代碼具體了解。
#include <stdio.h> binarySearch(int a[], int n, int key){ int low = 0; int high = n - 1; while(low<= high){ int mid = (low + high)/2; int midVal = a[mid]; if(midVal<key) low = mid + 1; else if(midVal>key) high = mid - 1; else return mid; } return -1; } int main(){ int i, val, ret; int a[8]={-32, 12, 16, 24, 36, 45, 59, 98}; for(i=0; i<8; i++) printf("%d\t", a[i]); printf("\n請(qǐng)輸人所要查找的元素:"); scanf("%d",&val); ret = binarySearch(a,8,val); if(-1 == ret) printf("查找失敗 \n"); else printf ("查找成功 \n"); return 0; }
運(yùn)行結(jié)果:
-32 12 16 24 36 45 59 98
請(qǐng)輸入所要查找的元素:12
查找成功
在上面的代碼中,我們成功地通過(guò)二分査找算法實(shí)現(xiàn)了查找功能,其實(shí)現(xiàn)過(guò)程如下圖所示。
在如上圖所示的查找過(guò)程中,先將序列中間位置的元素與所要査找的元素進(jìn)行比較,發(fā)現(xiàn)要査找的元素位干該位置的左部分序列中。接下來(lái)將mid的左邊一個(gè)元素作為 high,繼續(xù)進(jìn)行二分査找,這時(shí)mid所對(duì)應(yīng)的中間元素剛好是所要査找的元素,査找結(jié)束,返回査找元素所對(duì)應(yīng)的下標(biāo)。在main函數(shù)中通過(guò)返回值來(lái)判斷査找是否成功,如果査找成功.就打印輸出“査找成功”的信息,否則輸出“査找失畋”的信息。
以上就是對(duì)二分查找法的詳細(xì)介紹,希望學(xué)習(xí) C語(yǔ)言的同學(xué)可以掌握。
相關(guān)文章
C++使用sort對(duì)容器排序的實(shí)現(xiàn)
C++ STL 標(biāo)準(zhǔn)庫(kù)中的sort()函數(shù)專(zhuān)門(mén)用來(lái)對(duì)容器或普通數(shù)組中指定范圍內(nèi)的元素進(jìn)行排序,本文就詳細(xì)的介紹一下怎么實(shí)現(xiàn),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05C語(yǔ)言自定義數(shù)據(jù)類(lèi)型的結(jié)構(gòu)體、枚舉和聯(lián)合詳解
這篇文章主要給大家介紹了關(guān)于C語(yǔ)言自定義數(shù)據(jù)類(lèi)型的結(jié)構(gòu)體、枚舉和聯(lián)合的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05如何基于C語(yǔ)言socket編程實(shí)現(xiàn)TCP通信
本文介紹了如何基于C語(yǔ)言socket編程實(shí)現(xiàn)TCP通信,下面小編來(lái)簡(jiǎn)單介紹下2019-05-05詳解如何用c++實(shí)現(xiàn)平衡二叉樹(shù)
平衡二叉樹(shù)(Balanced Binary Tree)又被稱(chēng)為AVL樹(shù)(有別于AVL算法),由前蘇聯(lián)的數(shù)學(xué)家Adelse-Velskil和Landis在1962年提出的高度平衡的二叉樹(shù),根據(jù)科學(xué)家的英文名也稱(chēng)為AVL樹(shù)。本文介紹了它的原理和如何用C++代碼來(lái)實(shí)現(xiàn)2021-06-06C++ vector容器實(shí)現(xiàn)貪吃蛇小游戲
這篇文章主要為大家詳細(xì)介紹了C++ vector容器實(shí)現(xiàn)貪吃蛇小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02C++利用容器查找重復(fù)列功能實(shí)現(xiàn)
本文將詳細(xì)介紹c++容器簡(jiǎn)介,c++容器的比較 與操作實(shí)例,需要了解更多的朋友可以參考下2012-11-11C語(yǔ)言雙指針多方法旋轉(zhuǎn)數(shù)組解題LeetCode
這篇文章主要為大家介紹了C語(yǔ)言雙指針使用多方法旋轉(zhuǎn)數(shù)組題解LeetCode,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-02-02