本题要求编写程序,先将输入的一系列整数中的最小值与第一个数交换,然后将最大值与最后一个数交换,最后输出交换后的序列。
注意:题目保证最大和最小值都是唯一的。
输入格式: 输入在第一行中给出一个正整数N(≤10),第二行给出N个整数,数字间以空格分隔。
输出格式: 在一行中顺序输出交换后的序列,每个整数后跟一个空格。
输入样例: 5 8 2 5 1 4 输出样例: 1 2 5 4 8
#include<stdio.h> #define maxn 10 void swap(int *a,int *b); int find_min(int a[],int len); int find_max(int a[],int len); int main() { int n,a[maxn],min,max; scanf("%d",&n); for(int i=0;i<n;i++) scanf("%d",&a[i]); min=find_min(a,n); if(min!=0) swap(&a[min],&a[0]); max=find_max(a,n); if(max!=n-1) swap(&a[max],&a[n-1]); for(int i=0;i<n;i++) printf("%d ",a[i]); return 0; } int find_min(int a[],int len){ int min=0; for(int i=0;i<len;i++){ if(a[i]<a[min]) min=i; } return min; } int find_max(int a[],int len){ int max=0; for(int i=0;i<len;i++){ if(a[i]>a[max]) max=i; } return max; } void swap(int *a,int *b){ int t=*a; *a=*b; *b=t; }