来一个C语言二分法查找、找到 输出 找不到 给出提示 10个整数的就行了~

百度复制过来的就不要来了、请先测试可用再来谢谢~~楼主写这个代码时遇到的问题:循环变量不知如何控制、... 百度复制过来的就不要来了、 请先测试可用再来 谢谢~~
楼主写这个代码时遇到的问题:循环变量不知如何控制、
展开
 我来答
百度网友4323b7e40
2012-11-20 · TA获得超过591个赞
知道小有建树答主
回答量:199
采纳率:0%
帮助的人:162万
展开全部
#include<stdio.h>
void main()
{
int beg=0,end=0,mid=0;
int num=0;
int a[8]={1,3,5,9,11,24,56,89};
printf("请输入要查找的数!\n");
scanf("%d",&num);
beg=0;
end=7;
while(beg<end)
{
mid=(beg+end)/2;
if(a[mid]==num)
{
printf("第%d个元素是要找的元素\n",mid+1);
break;
}
else if(a[mid]<num)
{
beg=mid+1;
}
else
{
end=mid-1;
}
}
if(beg>=end)
{
printf("查找失败!\n");
}
}
追问
哥们 你测试了吗? 果断有问题的代码、
追答
#include
void main()
{
int beg=0,end=0,mid=0;
int num=0;
int a[8]={1,3,5,9,11,24,56,89};
printf("请输入要查找的数!\n");
scanf("%d",&num);
beg=0;
end=7;
while(begend)
{
printf("查找失败!\n");
}
}
这样就行了。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
qmaoting
2012-11-20 · TA获得超过217个赞
知道小有建树答主
回答量:112
采纳率:100%
帮助的人:101万
展开全部
递归版的(数组要有序):

int biSearch(int a[], int left, int right, int key)
{
if(left > right) return -1; //未找到
mid = (left + right)/2;
if(a[mid] == key) return mid; //返回找到的下标
return (a[mid] < key ? biSearch(a, mid+1, right) : biSearch(a, left, mid-1));
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式