输入一个数组,以负一为结束,用递归找到数组中的最大值,我感觉没有错误,但是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;
}

你的递归函数没有出口,也就没有边界 会一直往下递归。加个递归的边界判断,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;
}