7-20 交換最小值和最大值 (15分)
本題要求編寫程序,先將輸入的一系列整數中的最小值與第一個數交換,然后將最大值與最后一個數交換,最后輸出交換后的序列。
注意:題目保證最大和最小值都是唯一的。
輸入格式:
輸入在第一行中給出一個正整數N(≤10),第二行給出N個整數,數字間以空格分隔。
輸出格式:
在一行中順序輸出交換后的序列,每個整數后跟一個空格。
輸入樣例:
5
8 2 5 1 4
輸出樣例:
1 2 5 4 8
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);
int i;
int a[n];
for(i=0;i<n;i++)
{
scanf("%d",a+i);
}
int max=0,min=0;
for(i=1;i<n;i++)
{
if(a[i]>a[max])
{
max=i;
}
if(a[i]<a[min])
{
min=i;
}
}
int temp;
temp=a[min];
a[min]=a[0];
a[0]=temp;
if(max==0)
{
max=min;
}
temp=a[max];
a[max]=a[n-1];
a[n-1]=temp;
for(i=0;i<n;i++)
{
printf("%d ",a[i]);
}
return 0;
}
