C语言笔记10--二分法查找

二分法查找适合用在数据量大的方面查找,并且数据是要排序好的,每次和中值比较淘汰掉一半,直到找到需要的值退出。
下面笔者实现在0-1023中查找数据。

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
void main()
{
    int a[1024];//储存数据
    int num;
    int top,bottom,mid;
    for(int i=0;i<1024;i++)
    {
        a[i]=i;
    }
    printf("请输入要查找的数:");
    scanf("%d",&num);
    top=1023;
    bottom=0;
    while(top>bottom)
    {
        mid=(top+bottom)/2;//中值下标
        printf("top=%d,mid=%d,bottom=%d\n",top,mid,bottom);
        if(a[mid]==num)//中值和num相等即找到
        {
            printf("找到\n");
            break;//退出
        }
        else if(a[mid]<num)//num在上半部分
        {
            bottom=mid+1;
        }
        else//a[mid]>num,num在下半部分
        {
            top=mid-1;
        }
    }
    system("pause");
}

打印结果
这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值