码迷,mamicode.com
首页 > 编程语言 > 详细

查找算法——二分查找

时间:2018-06-28 19:26:39      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:eof   while   inf   image   main   TE   技术   版本   sea   

一、C 程序实现

/*******************************************************************************************
*Description 二分查找算法
*Author liaoxiongxiong
*Version 1.0
*Time 2018-04-28
*******************************************************************************************/

#include <stdio.h>

//二分查找,版本1
int BinarySearch1(int a[], int value, int n)
{
    int low, high, mid;
    low = 0;
    high = n-1;
    while(low<=high)
    {
        mid = (low+high)/2;
        if(a[mid] == value)
            return mid;
        if(a[mid]>value)
            high = mid-1;
        if(a[mid]<value)
            low = mid+1;
    }
    return -1;
}

//二分查找,版本2,递归版本
int BinarySearch2(int a[], int value, int low, int high)
{
    int mid = low+(high-low)/2;
    if(a[mid]==value)
        return mid;
    if(a[mid]>value)
        return BinarySearch2(a, value, low, mid-1);
    if(a[mid]<value)
        return BinarySearch2(a, value, mid+1, high);
}

//测试用例
int main()
{
    int a[]={0,1,2,3,4,5,6,7,8,9};
    int len = sizeof(a)/sizeof(a[0]);

    int x=2;   // 需要查找的元素

    int i = BinarySearch2(a, x, 0, len);
    if(i!=-1)
        printf("元素 %d 在第 %d 个位置\n",x,i+1);
    else
        printf("没有找到元素:%d\n",x);

    return 0;
}

运行结果:

技术分享图片

查找算法——二分查找

标签:eof   while   inf   image   main   TE   技术   版本   sea   

原文地址:https://www.cnblogs.com/shujuxiong/p/9240082.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!