问题是 pta天梯赛的善良 这么做哪里错了?

#include<stdio.h>
int main()
{
int N,a,min,max,n=1,m=1,x=1000000,y=0;
scanf("%d\n",&N);
scanf("%d",&a);
if(a<=x&&a>y)
max=min=a;
for(int i=1;i<N;i++){
scanf("%d",&a);
if(max<a) max=a;
if(max==a) n++;
if(min>a) min=a;
if(min==a) m++;
}
printf("%d %d\n",min,m);
printf("%d %d",max,n);
return 0;
}

主要问题,可能是判断最大值和最小值的地方出了点问题,因为最大值和最小值需要在所有输入完成后才能判断哪些最大,哪些最小,
在输入的同时既计算最大最小值,又统计最大和最小值的个数,似乎是难以同时完成,修改如下:

#include<stdio.h>
int main()
{
    //根据N的最大值创建数组a,根据N的最大值设置min的初始值为10^6,根据是正整数,设置m的初始值0 
    int N,a[20000],min=1000000,max=0,n=0,m=0;
    int i;
    scanf("%d",&N);
//    scanf("%d",&a);
//    if(a<=x&&a>y)
//    max=min=a;
    //获取输入,然后判断输入中的最大值和最小值 
    for(i=0;i<N;i++){
        scanf("%d",&a[i]);
        if(max<a[i]) max=a[i];
    //    if(max==a) n++;
        if(min>a[i]) min=a[i];
    //    if(min==a) m++;
    }
    
    
    //通过再次遍历,统计最大值max和最小值min的人数 
    for(i=0;i<N;i++){
        
        if(a[i]==max){
            m++;
        }
        
        if(a[i]==min){
            n++;
        }
    }
    
    //打印结果 
    printf("%d %d\n",min,n);
    printf("%d %d",max,m);
    return 0;
}