国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C > 正文

C 二分查找 遞歸與非遞歸的實現代碼

2020-01-26 16:20:08
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

#include <stdio.h>

int binSearch(int arr[], int low, int high, int key);
int binSearch2(int arr[], int low, int high, int key);
int binSearch3(int arr[],int start,int ends,int key);
int main() {
    int arr[]={3,8,11,15,17,22,23,26,28,29,34};
    //printf("%d",binSearch(arr,0,10,26));
    printf("%d",binSearch3(arr,0,10,26));
    return 1;
}

int binSearch(int arr[], int low, int high, int key) {
    int flag=-1;
    int mid = (low + high) / 2;
    if (low > high) {
        flag= -1;
    } else {

        if (arr[mid] < key) {
            flag= binSearch(arr, mid + 1, high, key);
        } else if (arr[mid]>key) {
            //比如要找的節點在下面這一層   那么這一層會返回下標上來 用flag接住嘛...
            flag= binSearch(arr,low,mid-1,key);//又差一點忘記了用flag取接住返回值了

        } else {
            flag= mid;
        }
    }
    return flag;
}


//ok==============================
int binSearch2(int arr[], int low, int high, int key) {
    int mid = (low + high) / 2;
    if (low > high) {
        return -1;
    } else {

        if (arr[mid] < key) {
            return binSearch2(arr, mid + 1, high, key);
        } else if (arr[mid]>key) {
            return binSearch2(arr,low,mid-1,key);
        } else {
            return mid;
        }
    }

}

int binSearch3(int arr[],int start,int ends,int key){
    int mid=-1;
    while(start<=ends){
        mid=(start+ends)/2;
        if(arr[mid]<key){
            start=mid+1;
        }else if(arr[mid]>key){
            ends=mid-1;
        }else{
            break;
        }
    }//上述循環結束后不一定就是 start>ends的  因為有break語句
    if(start>ends){
        mid=-1;
    }
    return mid;
}       

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 张北县| 明光市| 遂平县| 津南区| 凤山市| 郁南县| 台山市| 吴堡县| 崇仁县| 通山县| 安陆市| 建瓯市| 商南县| 罗甸县| 华阴市| 合肥市| 织金县| 湘潭市| 清流县| 五常市| 沾益县| 行唐县| 安远县| 秦皇岛市| 南京市| 铜鼓县| 确山县| 定边县| 叙永县| 南充市| 广汉市| 伊川县| 通山县| 吉林市| 买车| 新泰市| 定结县| 临猗县| 寿宁县| 兰西县| 辽宁省|