时间限制 : 1.000 sec 内存限制 : 32 MB
题目描述
输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。要求用3个函数实现,分别为输入10个数、进行处理、输出10个数。要求使用指针的方法进行处理。
输入
用空格隔开的10个整数。
输出
输出进行题目描述操作之后的10个整数,每个整数之后输出一个空格。
请注意行尾输出换行。
样例输入 Copy
1 5 2 4 9 0 3 8 7 6
样例输出 Copy
0 5 2 4 6 1 3 8 7 9
#include<stdio.h>
#include<string.h>
void enter1(int *s) {
for (int i = 0; i < 10; i++) {
scanf("%d", s + i);
}
}
void change(int *s) {
int min = *s;
int max = *s;
int n1 = 0;
int n2 = 0;
for (int i = 0; i < 10; i++) {
if (*(s + i) > max) {
max = *(s+i);
n1=i;
}
if (*(s + i) < min) {
min = *(s+i);
n2=i;
}
}
int t1, t2;
//最小的数与第一个数对换
t1 = *s;
*s = *(s + n2);
*(s + n2) = t1;
//最大的数与最后一个数对换
t2 = *(s + 9);
*(s + 9) = *(s + n1);
*(s + n1) = t2;
}
void exit1(int *s) {
for (int i = 0; i < 10; i++) {
printf("%d ", *(s + i));
}
printf("\n");
}
int main() {
int s[20];
enter1(s);
change(s);
exit1(s);
return 0;
}