: 。 2021-11-25 19:59 采纳率: 100%
浏览 19
已结题

我这个二分法的左右端点输出错误是为什么呀

#include<stdio.h>
int search(int a[],int x,int y)
{
int left=0;
int right=x-1;
while(a[left]<=a[right])
{
int middle=(left+right)/2;
if(a[middle]>y)
{
left=middle+1;
}
else if(a[middle]<y)
{
right=middle-1;
}
else
{
return middle;
}
}
return -1;
}
int main()
{
int a,b,c,d;
int g[10000];
while(1)
{
printf("请输入数组长度\n");
scanf("%d",&a);

printf("请输入你的数组数据\n");
for(b=0;b<a;b++)
{
    scanf("%d",&g[b]);
}
printf("请输入你需要查找的数字\n");
scanf("%d",&c);
d=search(g,a,c);
printf("%d是该数组中的第%d个\n",c,d+1);
}

return 0;
}

img

  • 写回答

2条回答 默认 最新

  • 南七灵 2021-11-25 20:12
    关注

    while (left <= right)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 11月25日
  • 已采纳回答 11月25日
  • 创建了问题 11月25日

悬赏问题

  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加
  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测