zzk.213 2021-11-12 15:14 采纳率: 87.8%
浏览 22
已结题

输入一个数组,以负一为结束,用递归找到数组中的最大值,我感觉没有错误,但是printf出来没有结果

#include <stdio.h>
int sort(int arr[],int n);
int main()
{
int i,a[50];
int t;
int count=0;
setvbuf(stdout,NULL,_IONBF,0);
printf("Input some integers:");
for(i=0;i<50;i++)
{
scanf("%d",&a[i]);
if(a[i]==-1)break;
count++;
}
t=sort(a,count);
printf("max=%d",t);
}
int sort(int arr[],int n)
{
int max;
max=sort(arr,n-1);
if(max<arr[n-1])
{
max=arr[n-1];
}
return max;
}

  • 写回答

1条回答 默认 最新

  • xiaopengO 2021-11-12 15:31
    关注

    你的递归函数没有出口,也就没有边界 会一直往下递归。加个递归的边界判断,n=1的时候直接返回。

    int sort(int arr[],int n)
    {
      if(n==1) return arr[0];
      int max;
      max=sort(arr,n-1);
      if(max<arr[n-1])
      {
        max=arr[n-1];
      }
      return max;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月20日
  • 已采纳回答 11月12日
  • 创建了问题 11月12日

悬赏问题

  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢
  • ¥15 不小心不正规的开发公司导致不给我们y码,
  • ¥15 我的代码无法在vc++中运行呀,错误很多
  • ¥50 求一个win系统下运行的可自动抓取arm64架构deb安装包和其依赖包的软件。
  • ¥60 fail to initialize keyboard hotkeys through kernel.0000000000
  • ¥30 ppOCRLabel导出识别结果失败
  • ¥15 Centos7 / PETGEM
  • ¥15 csmar数据进行spss描述性统计分析
  • ¥15 各位请问平行检验趋势图这样要怎么调整?说标准差差异太大了
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题