您好,登錄后才能下訂單哦!
二分查找
二分查找算法,說白了就是在有序的數(shù)組里面給予一個存在數(shù)組里面的值key,然后將其先和數(shù)組中間的比較,如果key大于中間值,進(jìn)行下一次mid后面的比較,直到找到相等的,就可以得到它的位置。
前提:線性表中的記錄必須是關(guān)鍵字有序(通常從小到大),線性表必須采用順序存儲。
基本思想:取中間記錄作為比較對象,若給定值與中間記錄的關(guān)鍵字相等,則查找成功;若給定值小于中間記錄的關(guān)鍵字,則在中間記錄的左半?yún)^(qū)繼續(xù)查找;否則,在右半?yún)^(qū)查找。不斷重復(fù),直到查找成功或查找失敗為止。
#include<iostream> #include<stdio.h> #define N 10 using namespace std; int main() { int a[N],front,end,mid,i,x; cout<<"請輸入已經(jīng)排好的序列10個:"<<endl; for(i=0;i<N;i++) { cin>>a[i]; } cout<<"請輸入要查詢的數(shù)字x"<<endl; cin>>x; front=0; end=N-1; mid=(front+end)/2; while(front<end&&a[mid]!=x) { if(a[mid]>x) end=mid-1; if(a[mid]<x) front=mid+1; mid=(front+end)/2; } if(a[mid]!=x) { printf("找不到該數(shù)字!"); } else { printf("找到了,該數(shù)字在第%d位置",mid+1); } return 0; }
后記:
查找和排序都是在程序設(shè)計中經(jīng)常用到的算法,查找相對而言較為簡單,不外乎順序查找、二分查找、哈希表查找和二叉排序樹查找。
在面試的時候,不管是用循環(huán)還是用遞歸,面試官都期待應(yīng)聘者能夠信手拈來寫出完整的二分查找代碼,否則可能連繼續(xù)面試的興趣都沒有。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對億速云的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。