由N个有序整数组成的数列已放在一维数组中,给定程序MODI1.C中函数fun的功能是:利用折半查找算法查找整数m在数组中的位置。若找到,返回其下标值;反之,返回-1。
#include <stdio.h>
#define N 10
/************found************/
void fun(int a[], int m )
{ int low=0,high=N-1,mid;
while(low<=high)
{ mid=(low+high)/2;
if(m<a[mid])
high=mid-1;
/************found************/
else If(m > a[mid])
low=mid+1;
else return(mid);
}
return(-1);
}
main()
{ int i,a[N]={-3,4,7,9,13,45,67,89,100,180 },k,m;
printf("a数组中的数据如下:");
for(i=0;i<N;i++) printf("%d ", a[i]);
printf("Enter m: "); scanf("%d",&m);
k=fun(a,m);
if(k>=0) printf("m=%d,index=%d\n",m,k);
else printf("Not be found!\n");
}
void fun(int a[], int m ) /* 把void删掉或改为int */
{ int low=0,high=N-1,mid;
while(low<=high)
{ mid=(low+high)/2;
if(m<a[mid])
high=mid-1;
/************found************/
else If(m > a[mid]) /* If 改成小写 if */追问
我考试的时候删掉了 但答案说改为int 以为错了 谢谢 嘿嘿 多谢啦
追答C语言规定,函数的类型如为int 或 void 可以省去不写
#include <stdio.h>
#define N 10
/************found************/
int fun(int a[], int m )
{ int low=0,high=N-1,mid;
while(low<=high)
{ mid=(low+high)/2;
if(m<a[mid])
high=mid-1;
/************found************/
else if(m > a[mid])
low=mid+1;
else return(mid);
}
return(-1);
}
main()
{ int i,a[N]={-3,4,7,9,13,45,67,89,100,180 },k,m;
printf("a数组中的数据如下:");
for(i=0;i<N;i++) printf("%d ", a[i]);
printf("Enter m: "); scanf("%d",&m);
k=fun(a,m);
if(k>=0) printf("m=%d,index=%d\n",m,k);
else printf("Not be found!\n");
}追问
第一个把void 删掉正确吗
追答对的,因为int也可以省略。
改为int fun(int a[], int m )追问
第一个把void 删掉正确吗 调试结果没错
追答个人觉得加上比较好,符合C99的标准写法。如果那样写的话感觉函数的返回值类型和函数有没有返回值是不太清晰的,程序的可读性就差了
追问谢谢 我只是为了考计算机二级 对了就行 谢谢
追答不客气~~~
本回答被提问者采纳2.return 后需要空格
3.函数fun中第二个if应该小写
4.main函数默认不是void类型需要return 0