随笔 - 493  文章 - 0  评论 - 97  阅读 - 239万

二分法在数组中查找关键字

/*
    此程序演示了二分法查找算法(针对按从小到大排列的数组)的实现。
*/
 
#include <iostream>
 
using namespace std;
 
/*
    功能: 实现数组的二分法查找(只算法只适合按从小到大排列的数组)
    返回值:关键字在数组中的下标, 返回-1表示未找到
    a[]:    要搜索的数组
    len:    数组元素个数
    key:    要查找的关键字
*/
int binSearch(int a[], int len, int key)
{
    int i = len / 2;
    int ii = 0;
    if(len < 1)
        return -1;
 
    if((key > a[i]) && (len - i > 0))
    {
        ii = binSearch(a+i+1, len - i - 1, key);    // 在后半段数组中查找
        if(ii != -1)
            return ii + i + 1;                      // 加上数组前半段的长度
        else
            return -1;
    }
    else if(key < a[i] && i > 0)                  // 在前半段数组中查找
        return binSearch(a, i, key);
    else if(key == a[i])
        return i;                                   // 返回关键字在数组中的下标
    else
        return -1;                                  // 未在数组中找到关键字
}
 
int main()
{
    int a[] = {2, 4, 5, 20, 24, 35, 66, 78, 98};
    int len = sizeof(a) / sizeof(int);
    int i, key = -1;
 
    while(1)
    {
        cin>>key;
        i = binSearch(a, len, key);
        printf("%d\n", i);
        if(key > 100)
            break;
    }
 
    return 0;
}
posted on   清清飞扬  阅读(3172)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET10 - 预览版1新功能体验(一)
< 2011年6月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 1 2
3 4 5 6 7 8 9

点击右上角即可分享
微信分享提示