程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程綜合問答 >> c++-一個二分搜索的遞歸函數問題

c++-一個二分搜索的遞歸函數問題

編輯:編程綜合問答
一個二分搜索的遞歸函數問題

使用函數 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; 

}
測試通過

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved