[求助] 二分法的问题
#include "stdio.h"
int arry[10]={1,2,3,4,5,6,7,8,9,10};
main ()
{
int x;
x=fun (arry, 8, 10);
printf ("x=%d\n", x);
getch ();
}
int fun (int *a, int num, int size)
{
int h=size, l=0, m;
int i=5;
while (l<=h)
{
m=(l+h)/2;
if (a[m]==num)
return a[m];
else if (a[m]>num)
h=m;
else if (a[m]<num)
l=m;
}
return -1;
}
为什么这个程序查找小于1和大于10的数时没有任何输出?
请各位帮忙分析。