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-2025 CODEPRJ.COM