国产探花免费观看_亚洲丰满少妇自慰呻吟_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;
}       

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

圖片精選

主站蜘蛛池模板: 寿光市| 饶平县| 正镶白旗| 桐城市| 蒲江县| 甘谷县| 清流县| 临汾市| 文昌市| 饶平县| 武汉市| 越西县| 聂拉木县| 台南市| 东光县| 临漳县| 温泉县| 阿勒泰市| 河北区| 丽江市| 苍南县| 原平市| 沾益县| 旌德县| 兴文县| 乐陵市| 观塘区| 阿克苏市| 南陵县| 年辖:市辖区| 乌海市| 钟山县| 雅安市| 玉林市| 湄潭县| 十堰市| 惠州市| 文安县| 涟水县| 陆良县| 邛崃市|