91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在c語言中使用二分法查找數組中的元素

發布時間:2021-03-17 15:48:40 來源:億速云 閱讀:308 作者:Leah 欄目:編程語言

今天就跟大家聊聊有關怎么在c語言中使用二分法查找數組中的元素,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

c語言二分法實現查找數組元素的方法:

遞歸算法

#include<stdio.h>
//二分法實現數組查找
 
//
int recurbinary(int *a, int key, int low, int high)
{
    int mid;
    if(low > high)
        return -1;
    mid = (low + high)/2;
    if(a[mid] == key) return mid;
    else if(a[mid] > key)
         return recurbinary(a,key,low,mid -1);
    else
         return recurbinary(a,key,mid + 1,high);
 
}

非遞歸算法

int binary( int *a, int key, int n )
{
    int left = 0, right = n - 1, mid = 0;
    mid = ( left + right ) / 2;
    while( left < right && a[mid] != key )
    {
        if( a[mid] < key ) {
            left = mid + 1;
        } else if( a[mid] > key ) {
            right = mid - 1;
        }
        mid = ( left + right ) / 2;
    }
    if( a[mid] == key )
        return mid;
    return -1;
}
 
int main(void)
{
int a[10] = {2,4,6,8,10,12,14,16,18,20},t,k,f;
scanf("%d",&t);
k = recurbinary(a,t,2,20);
f = binary(a,t,10);  //非遞歸算法
if(k == -1){
printf("不存在此數\n");
}else{
printf("%-5d是數組第%d個元素\n%-5d數組的第%d個元素",k,k+1,f,f+1);
}
 
return 0;
}


看完上述內容,你們對怎么在c語言中使用二分法查找數組中的元素有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

治多县| 章丘市| 濉溪县| 略阳县| 临夏市| 乐陵市| 外汇| 永川市| 商南县| 赤城县| 泸州市| 商都县| 北宁市| 乌苏市| 南宫市| 察雅县| 平南县| 福泉市| 浠水县| 芦溪县| 古交市| 海门市| 阿巴嘎旗| 海南省| 南岸区| 武鸣县| 绵阳市| 宁乡县| 海门市| 怀仁县| 福海县| 兴国县| 汤阴县| 江源县| 安庆市| 祁阳县| 类乌齐县| 清流县| 景东| 和林格尔县| 宜昌市|