本題要求編寫程序,先將輸入的一系列整數中的最小值與第一個數交換,然后將最大值與最后一個數交換,最后輸出交換后的序列。
注意:題目保證最大和最小值都是唯一的。
輸入格式:
輸入在第一行中給出一個正整數N(≤10),第二行給出N個整數,數字間以空格分隔。
輸出格式:
在一行中順序輸出交換后的序列,每個整數后跟一個空格。
輸入樣例:
5
8 2 5 1 4
輸出樣例:
1 2 5 4 8
1 #include<stdio.h> 2 int main(){ 3 int N,i,t,a[10]; 4 scanf("%d",&N); 5 for(i=0;i<N;i++) { 6 scanf("%d",&a[i]); 7 } 8 int min=0;/*先假設min值下標為0*/ 9 for(i=1;i<N;i++) { /*然后從下標1開始依次和下標min比較大小*/ 10 if(a[i]<a[min]) /*如果a[i]<a[]min,就把i賦值於min*/ 11 min=i;/*用min來存最小值的小標*/ 12 } /*通過上面語句找出最小值a[min]*/ 13 t=a[0]; /*把數組的第一值a[0]賦值於t*/ 14 a[0]=a[min];/*再把最小值啊a[min]賦值於a[0],這樣第一個數就是最小值啦*/ 15 a[min]=t;/*然后在把之前存放在t的數組第一個值賦值與a[min]*/ 16 /*通過上面的三條語句就實現交換啦*/ 17 int max=0; 18 for(i=1;i<N;i++) { 19 if(a[i]>a[max]) 20 max=i; 21 } 22 t=a[N-1]; 23 a[N-1]=a[max]; 24 a[max]=t;/*關於最大值交換同上*/ 25 for(i=0;i<N;i++) { 26 printf("%d ",a[i]); 27 } 28 return 0; 29 }
