: 。 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日