#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;
}
输入一个数组,以负一为结束,用递归找到数组中的最大值,我感觉没有错误,但是printf出来没有结果
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥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组件网页下拉菜单自动选择问题