Lionel Messi941 2021-12-24 20:57 采纳率: 100%
浏览 15
已结题

二分查找,找不出正确的

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int comb(const voida,const voidb)
{
return (int)a-(int)b;
}
int main(){
int n,m;
int a[1000]={0};
scanf("%d",&n);
scanf("%d",&m);
for(int i=0;i<n;i++){
scanf("%d",&a[i]);
}
qsort(a,n,sizeof(int),comb);
/for(int i=0;i<n;i++){
printf("%d ",a[i]);
}
/

int low=0,high=n-1,q=0,j=0,middle;
for(int k=0;;k++){
    middle=(low+high)/2;
    if(m>a[middle]){
        low=middle+1;
        j+=1;
    }
    else if(m<a[middle]){
        high=middle-1;
        j+=1;
    }
    else if(m==a[middle]){
        q=1;
    }
    if(low>high){
        break;
    }
}
if(q==0){
    printf("-1\n%d",j);
}
else if(q==1){
    printf("%d\n%d",middle,j);
}
return 0;

}

  • 写回答

1条回答 默认 最新

  • CSDN专家-link 2021-12-24 21:14
    关注

    在q=1后,你得break终止继续循环啊

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

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 如何制作永久二维码,最好是微信也可以扫开的。(相关搜索:管理系统)
  • ¥15 delphi indy cookie 有效期
  • ¥15 labelme打不开怎么办
  • ¥35 按照图片上的两个任务要求,用keil5写出运行代码,并在proteus上仿真成功,🙏
  • ¥15 免费的电脑视频剪辑类软件如何盈利
  • ¥30 MPI读入tif文件并将文件路径分配给各进程时遇到问题
  • ¥15 pycharm中导入模块出错
  • ¥20 Ros2 moveit2 Windows环境配置,有偿,价格可商议。
  • ¥15 有关“完美的代价”问题的代码漏洞
  • ¥15 请帮我看一下这个简易化学配平器的逻辑有什么问题吗?