不厭徐何 2023-03-21 23:01 采纳率: 56.5%
浏览 31
已结题

折半查找问题-c语言

输入989的时候,一回车什么都没有,不知道什么原因


    fflush (stdin);
    int a[15]={98,87,76,65,54,43,32,21,18,17,9,8,7,6,5};
    int i,n,left=0,right=14,mid;  //i是数组下标,n是要查找的数 
    int flag=0;
    scanf("%d",&n);
    while(left<=right){
        mid=(left+right)/2;
        if(a[mid]>n){
            left=mid;
        }
        else if(a[mid]<n){
            right=mid;
            }
            else if(a[mid]==n) {
                flag=1;    
                break;
                }
    }
    if(flag){
        printf("该数是数组中第%d个元素",mid+1);
    }
    else printf("查无此数");
  • 写回答

2条回答 默认 最新

  • Huazie 全栈领域优质创作者 2023-03-21 23:24
    关注
    • 死循环了吧, left 要变大, right 要变小
    • 参考如下修改:
    #include <stdio.h>
    
    
    int main(void)
    {
        int a[15]={98,87,76,65,54,43,32,21,18,17,9,8,7,6,5};
        int n,left=0,right=14,mid;  //i是数组下标,n是要查找的数 
        int flag=0;
        scanf("%d",&n);
        while(left<=right)
        {
            mid=(left+right)/2;
            if(a[mid]>n)
            {
                left=mid+1; // left 要变大
            }
            else if(a[mid]<n)
            {
                right=mid-1; // rigth 要变小
            }
            else if(a[mid]==n) 
            {
                flag=1;    
                break;
            }
        }
        if(flag)
            printf("该数是数组中第%d个元素",mid+1);
        else 
            printf("查无此数");
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月29日
  • 已采纳回答 3月21日
  • 创建了问题 3月21日

悬赏问题

  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 linux驱动,linux应用,多线程