|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
#define M 10
#include <stdio.h>
int main(void)
{
static int a[M]={-12,0,6,16,23,56,80,100,110,115};
int n,low,mid,high,found;
low=0;
high=M-1;
found=0;
printf("Input a number to be searched:");
scanf("%d",&n);
while ( scanf("%d",&n)!=1)
{
printf("Illegal input!!\nPlease input agin!!\n");
getchar();
}
while (low<=high)
{
mid=(low+high)/2;
if(n==a[mid])
{
found=1;break;
}
else if(n>a[mid])
{
low=mid;
}
else
{
high=mid;
}
}
if(found==1)
{
printf("有这个数并且在第%d项",mid+1);
}
else
{
printf("there is no %d",n);
}
}
你的问题已经解决,看注释
- #define M 10
- #include <stdio.h>
- int main(void)
- {
- static int a[M] = { -12,0,6,16,23,56,80,100,110,115 };
- int n, ret, low, mid, high, found;
- low = 0;
- high = M - 1;
- found = 0;
- printf("Input a number to be searched:");
- do // 使用 do ... while 语句,先执行一次 scanf()
- {
- ret = scanf("%d", &n); // 将 scanf() 函数的返回值赋给整型变量 ret
- if(ret != 1)
- printf("Illegal input!!\nPlease input agin!!\n");
- getchar(); // 吸收掉输入的错误字符,否则程序将死循环
- } while (ret != 1);
-
- while (low <= high)
- {
- mid = (low + high) / 2;
- if (n == a[mid])
- {
- found = 1; break;
- }
- else if (n > a[mid])
- {
- low = mid;
- }
- else
- {
- high = mid;
- }
- }
- if (found == 1)
- {
- printf("有这个数并且在第%d项", mid + 1);
- }
- else
- {
- printf("there is no %d", n);
- }
- }
复制代码
|
|