找出含有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;
}