|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
8-05 交换最小值和最大值 (20分)
本题要求编写程序,先将输入的一系列整数中的最小值与第一个数交换,然后将最大值与最后一个数交换,最后输出交换后的序列。
注意:题目保证最大和最小值都是唯一的。
输入格式:
输入在第一行中给出一个正整数N(≤10),第二行给出N个整数,数字间以空格分隔。
输出格式:
在一行中顺序输出交换后的序列,每个整数后跟一个空格。
输入样例:
5
8 2 5 1 4
输出样例:
1 2 5 4 8
(20分)
作者
C课程组
单位
浙江大学
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
#include <stdio.h>
int main()
{
int t,N,i,j,J,T,min,max,a[100],b[100];
scanf("%d",&N);
for(i=0;i<N;i++)
{
scanf("%d",&a[i]);
}
min=max=a[0];
for(i=0;i<N;i++){
if(min>=a[i]){
min = a[i];
j = i;
}
}
t = a[0];
a[0] = min;
a[j] = t;
for(i=0;i<N;i++)
{
if(max<a[i]){
max = a[i];
J = i;
}
}
T = a[N-1];
a[N-1] = max;
a[J] = T;
for(i=0;i<N;i++)
{
printf("%d ",a[i]);
}
return 0;
}//请问哪错了
本帖最后由 风过无痕1989 于 2020-12-7 02:15 编辑
- #include<stdio.h>
- void main()
- {
- int i, n, max, min, temp, a[5];
- scanf("%d", &n);
- int j = 0, k = n - 1;
- for (i = 0;i < n;i++)
- scanf("%d", &a[i]);
- min = a[0];
- //找到最数组中最大的元素,并与第一个元素交换
- for (i = 1; i < n; i++)
- {
- if (min > a[i])
- {
- min = a[i];
- j = i;
- }
- }
- temp = a[0]; // 将最小值与第1个元素交换位置
- a[0] = a[j];
- a[j] = temp;
- max = a[n - 1]; // 在最小值的位置确定后,设最后一个元素为最大值
- //找到最数组中最大的元素,并与最后一个元素交换
- for (i = 0; i < n - 1; i++)
- {
- if (max < a[i])
- {
- max = a[i];
- k = i;
- }
- }
- temp = a[n - 1]; // 将最大值与最后1个元素交换位置
- a[n - 1] = a[k];
- a[k] = temp;
- for (i = 0;i < n;i++) // 输出数组
- printf("%d ", a[i]);
- printf("\n");
- }
复制代码
|
|