欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

查找算法之二分查找的C++實(shí)現(xiàn)

 更新時(shí)間:2018年12月14日 08:53:30   作者:Struggler09  
今天小編就為大家分享一篇關(guān)于查找算法之二分查找的C++實(shí)現(xiàn),小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧

二分查找

二分查找算法,說(shuō)白了就是在有序的數(shù)組里面給予一個(gè)存在數(shù)組里面的值key,然后將其先和數(shù)組中間的比較,如果key大于中間值,進(jìn)行下一次mid后面的比較,直到找到相等的,就可以得到它的位置。

前提:線(xiàn)性表中的記錄必須是關(guān)鍵字有序(通常從小到大),線(xiàn)性表必須采用順序存儲(chǔ)。
基本思想:取中間記錄作為比較對(duì)象,若給定值與中間記錄的關(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<<"請(qǐng)輸入已經(jīng)排好的序列10個(gè):"<<endl;
for(i=0;i<N;i++)
{
cin>>a[i];
}
cout<<"請(qǐng)輸入要查詢(xún)的數(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ì)中經(jīng)常用到的算法,查找相對(duì)而言較為簡(jiǎn)單,不外乎順序查找、二分查找、哈希表查找和二叉排序樹(shù)查找。
在面試的時(shí)候,不管是用循環(huán)還是用遞歸,面試官都期待應(yīng)聘者能夠信手拈來(lái)寫(xiě)出完整的二分查找代碼,否則可能連繼續(xù)面試的興趣都沒(méi)有。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

相關(guān)文章

最新評(píng)論