#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; }本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报