| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 619 人关注过本帖
标题:关于一个小程序的问题
只看楼主 加入收藏
wst1123
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2011-9-9
收藏
 问题点数:0 回复次数:2 
关于一个小程序的问题
初学C写个小程序,我感觉find函数最后那个return应该有,但是加上后结果就不对了,求解释
#include<stdio.h>
#define N 5
int find(int a[],int x,int left,int right)
{
  int mid;
  if (left>right)
    return(0);
  else
  {
    mid=(left+right)/2;
    if(x==a[mid])
      return(mid+1);
    else
    {
     if(x>a[mid])
       find(a,x,a[mid]+1,right);
     else
       find(a,x,left,a[mid]-1);
    }
     return(mid+1);
}
}

void main()
{ int a[N],i,x,result;
  printf("input a[%d]:\n",N);
  for(i=0;i<N;i++)
    scanf("%d",&a[i]);
  printf("input the number x:\n");
    scanf("%d",&x);
  result=find(a,x,0,N-1);
  if(result==0)
    printf("wrong\n");
  else
    printf("a[%d]=%d\n",result,x);
}
搜索更多相关主题的帖子: include return result input right 
2011-10-29 00:12
buaazjn
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-10-29
收藏
得分:0 
应该return加在后两个find前,递归的逻辑,想明白就好了
2011-10-29 00:23
laznrbfe
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
帖 子:482
专家分:1599
注 册:2011-5-22
收藏
得分:0 
错误好多,递归那里错了,返回值弄错了。。。
2011-10-29 00:38
快速回复:关于一个小程序的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.026576 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved