PTA运行超时,VC6.0上能正常运行,不知那里出了问题,向各位取经

找出含有10个元素一维数组中的最大值和最小值,并互换这两个数的位置。
输入格式:
在一行中输入10个整数,数据之间只能用1个空格间隔。
输出格式:
在一行中按照“max=最大值,min=最小值”的格式输出结果,最大值和最小值均原样输出,没有列宽控制。
在下一行中输出交换完最大值和最小值的一维数组,每个数据输出占5列。
输入样例:
6 5 1 2 3 4 8 9 7 5
输出样例:
max=9,min=1
6 5 9 2 3 4 8 1 7 5
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
代码如下
#include<stdio.h>
int main()
{
int x=0,y=0,w=0,i=0,max=0,min=0,z[10]={0};
char c;
for(i=0;c=getchar()!='\n';i++)
{
scanf("%d",&z[i]);
}
for(i=0;i<10;i++)
{
if(z[i]>=max)
{
max=z[i];
x=i;
}
else
if(z[i]>=min)
{
min=z[i];
y=i;
}
}
w=max;z[x]=z[y];z[y]=w;
printf("max=%d min=%d\n",max,min);
for(i=0;i<10;i++)
{
printf(" %d",z[i]);
}
return 0;
}

修改如下,供参考:

#include<stdio.h>
int main()
{
    int x = 0, y = 0, w = 0, i = 0, max = 0, min = 0, z[10] = { 0 };
    //char c;
    for (i = 0; i < 10; i++)   //for (i = 0; c = getchar() != '\n'; i++)
    {
        scanf("%d", &z[i]);
    }
    max = min = z[0];       //修改
    for (i = 0; i < 10; i++)
    {
        if (z[i] > max)  //if (z[i] >= max)
        {
            max = z[i];
            x = i;
        }
        //else
        if (z[i] < min)   //if (z[i] >= min)
        {
            min = z[i];
            y = i;
        }
    }
    w = max; z[x] = z[y]; z[y] = w;
    printf("max=%d,min=%d\n", max, min);
    for (i = 0; i < 10; i++)
    {
        printf("%5d", z[i]);  //printf(" %d", z[i]);
    }
    return 0;
}