标题:[求助]折中查询程序.怎么运行没结果的啊
取消只看楼主
lhj2005
Rank: 1
等 级:新手上路
帖 子:230
专家分:0
注 册:2007-1-23
 问题点数:0 回复次数:1 
[求助]折中查询程序.怎么运行没结果的啊
#include <stdio.h>
int main()
{
int item[5]={10,11,12,13,14};
int low=0,high=4,x,mid;
scanf("%d",&x);
while(low<=high)
{
mid=(low+high)/2;
if(item[mid]==x)
break;
else if(x>item[mid])
low=mid+1;
else
high=mid-1;
}
return mid;
}

请高手知道下!!!
搜索更多相关主题的帖子: 折中 结果 int 运行 
2007-02-14 03:36
lhj2005
Rank: 1
等 级:新手上路
帖 子:230
专家分:0
注 册:2007-1-23
得分:0 

能帮我解释下:
low=mid+1;
high=mid-1;
的运算吗,我不能理解
x>item[mid]
low=mid+1;

在这里mid=(low+high)/2=(10+14)/2=12
当x=14=item[4]的时候,x>item[mid]
那么:low=mid+1在这里是什么作用啊

[此贴子已经被作者于2007-2-14 13:21:16编辑过]

2007-02-14 13:15



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-120892-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 1.471142 second(s), 10 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved