清祀. 2022-12-09 11:40 采纳率: 83.3%
浏览 20
已结题

二分法查找无法运行出正确结果

 ###### 二分法查找编译没有报错但是实现不了功能

//查找
        int l=0,r=9,t,mid;
        printf("\n输入要查找的值(不查找输入-1):");
        scanf("%d",&t); 
        while(t!=-1)
        {
            while(l<r)
            {
                mid=(l+r)/2;
                if(t<a[mid]){
                    l=mid+1;
                }
                else if(t>a[mid]){
                    r=mid-1;
                }
                else {
                printf("学号为:%d",s[mid]);
                break;
                }
            }
            if(l>r){
                printf("NO FOUND!!!");
            }
            printf("\n输入要查找的值(不查找输入-1):");
            scanf("%d",&t);
        }

  • 写回答

1条回答 默认 最新

  • 快乐鹦鹉 2022-12-09 11:42
    关注

    提供你的测试数据
    while(l<=r)
    另外外层while循环开始前,应该加上l=0,r=9,否则第二次循环时,l和r还是上次循环结束的值

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月17日
  • 已采纳回答 12月9日
  • 创建了问题 12月9日

悬赏问题

  • ¥15 救!ENVI5.6深度学习初始化模型报错怎么办?
  • ¥30 eclipse开启服务后,网页无法打开
  • ¥30 雷达辐射源信号参考模型
  • ¥15 html+css+js如何实现这样子的效果?
  • ¥15 STM32单片机自主设计
  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢
  • ¥15 不小心不正规的开发公司导致不给我们y码,
  • ¥15 我的代码无法在vc++中运行呀,错误很多
  • ¥50 求一个win系统下运行的可自动抓取arm64架构deb安装包和其依赖包的软件。
  • ¥60 fail to initialize keyboard hotkeys through kernel.0000000000