亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

怎么在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

信丰县| 长武县| 天柱县| 武陟县| 桃源县| 定日县| 南陵县| 邮箱| 周口市| 迭部县| 沁阳市| 陆河县| 海淀区| 长泰县| 南召县| 长宁县| 江口县| 叙永县| 揭阳市| 上饶县| 海阳市| 集贤县| 静乐县| 共和县| 武隆县| 福泉市| 临海市| 岱山县| 措勤县| 赣州市| 汝州市| 富平县| 宿迁市| 德格县| 桦甸市| 岑溪市| 普洱| 衡南县| 彭山县| 大庆市| 鹤峰县|