7-20 交換最小值和最大值 (15分)


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;
}


免責聲明!

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



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