本题要求编写程序,先将输入的一系列整数中的最小值与第一个数交换,然后将最大值与最后一个数交换,最后输出交换后的序列。
注意:题目保证最大和最小值都是唯一的。
输入格式:
输入在第一行中给出一个正整数N(≤10),第二行给出N个整数,数字间以空格分隔。
输出格式:
在一行中顺序输出交换后的序列,每个整数后跟一个空格。
输入样例:
输出样例:
WR
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
| #include<stdio.h> int main() { int n,temp,min=0,max=0; scanf("%d",&n); int a[n]; for(int i=0;i<n;i++) scanf("%d",&a[i]); for(int i=0;i<n;i++) { if(a[i]<a[min]) min=i; if(a[i]>a[max]) max=i; } temp = a[0]; a[0] = a[min]; a[min] = temp; temp = a[n-1]; a[n-1] = a[max]; a[max] = temp; for(int i=0;i<n;i++) printf("%d ",a[i]); }
|
AC
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
| #include<stdio.h> int main() { int n,temp,min=0,max=0; scanf("%d",&n); int a[n]; for(int i=0;i<n;i++) scanf("%d",&a[i]); for(int i=0;i<n;i++) { if(a[i]<a[min]) min=i; if(a[i]>a[max]) max=i; } temp = a[0]; a[0] = a[min]; a[min] = temp; for(int i=0;i<n;i++) { if(a[i]<a[min]) min=i; if(a[i]>a[max]) max=i; } temp = a[n-1]; a[n-1] = a[max]; a[max] = temp; for(int i=0;i<n;i++) printf("%d ",a[i]); }
|