C語言拯救計划Day4-4之交換最小值和最大值


本題要求編寫程序,先將輸入的一系列整數中的最小值與第一個數交換,然后將最大值與最后一個數交換,最后輸出交換后的序列。

注意:題目保證最大和最小值都是唯一的。

輸入格式:

輸入在第一行中給出一個正整數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 } 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM