使用函数 int binarysearch(int t,int x[],int n);
编写递归二分搜索算法,并且不使用其它辅助递归函数。
然后我编写的了如下代码:
int search(int t,int x[],int n)
{
int low=(n-1)/2;
if( x > x+n ) return -1;
if( t > x[low] )
{
search(t,x+low+1,n);
}
else if( t < low ){
search(t,x,low+2);
}
else
return low;
}
但是返回的位置却不是正确的,我明白为什么不正确,但是却找不到好的方法,谁能拯救一下我?
请看下面
int search(int t,int x[],int n)
{
int low=(n-1)/2;
if( x > x+n ) return -1;
if( t > x[low] )
{
return search(t,x+low+1,n-low-1) + low +1;
}
else if( t < x[low] ){
return search(t,x,low);
}
else
return low;
}
int search(int t,int x[],int n)
{
int low=(n-1)/2;
if( x > x+n ) return -1;
if( t > x[low] )
{
return search(t,x+low+1,n-low-1) + low +1;
}
else if( t < x[low] ){
return search(t,x,low);
}
else
return low;
}
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。