a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > 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;
}       

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

圖片精選

主站蜘蛛池模板: 成人a视频在线观看 | 国产99久久精品 | 国产精品一区二区无线 | 国产精品理论片在线观看 | 国产97久久| 久久99精品久久久久久久青青日本 | 二区视频| 中午字幕在线观看 | 一区二区亚洲 | 可以免费看av的网址 | www在线观看国产 | 精品久久久久久国产 | 久久精品亚洲精品国产欧美kt∨ | 中文字幕一区在线观看视频 | 欧美综合一区二区 | 一区二区国产精品 | 欧美一区三区 | 精品国自产在线观看 | 欧美一区免费 | 在线激情视频 | 久久久久久久999 | 日本欧美国产 | 免费的日本网站 | 成人福利av | 中文字幕亚洲在线观看 | 91九色国产视频 | 成人黄色在线视频 | 国产亚洲一区二区三区在线观看 | 成人精品在线播放 | 精品一区在线 | 99免费在线视频 | 日日干日日操 | 欧美激情精品久久久久久 | 欧美一级免费看 | 欧美日韩国产高清视频 | 蜜桃视频在线观看www社区 | 日日夜夜精品免费视频 | 精品国产一区二区在线 | 欧美一区二区三区四区视频 | 91久久国产综合久久91精品网站 | 欧美中文在线观看 |