QQ登录

只需一步,快速开始

搜索
查看: 80|回复: 0

折半递归,输出怎么都是错的,但是又看不出错在哪里,求助!

[复制链接]
最佳答案
0 
累计签到:3 天
连续签到:1 天
发表于 2017-10-11 16:18:07 | 显示全部楼层 |阅读模式

马上注册加入鱼C,享用更多服务吧^_^

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
本帖最后由 努力学习只是 于 2017-10-14 15:40 编辑

折半递归,输出怎么都是错的,但是又看不出错在哪里,求助!
  1. #include"iostream"
  2. using namespace std;
  3. int a[11]={1,2,3,14,15,23,26,29,35,41,49};
  4. int bresearch(int b,int low,int high){
  5.          if(low<=high){
  6.          int mid=(low+high)/2;
  7.          if(a[mid]==b)return mid+1;
  8.          if(a[mid]>b)
  9.              bresearch(b,low,mid-1);
  10.          if(a[mid]<b)  bresearch(b,mid+1,high);
  11.          }
  12. }
  13. int main(){

  14.    int n,key,high,low;
  15.    n=11;
  16.    high=n-1;
  17.    low=0;
  18.    cout<<"input a number:";
  19.    cin>>key;
  20.    cout<<bresearch(key,low,high);
  21. return 1;
  22. }
复制代码
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

小甲鱼强烈推荐上一条 /1 下一条

小黑屋手机版Archiver( 粤公网安备 44051102000370号 | 粤ICP备11014136号

© 2010-2017 FishC.com GMT+8, 2017-10-22 03:23 Powered by Discuz! X2.5 Theme by dreambred

快速回复 返回顶部 返回列表