题目描述
输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。要求用3个函数实现,分别为输入10个数、进行处理、输出10个数。要求使用指针的方法进行处理。
输入
用空格隔开的10个整数。
输出
输出进行题目描述操作之后的10个整数,每个整数之后输出一个空格。
请注意行尾输出换行。
样例输入
1 5 2 4 9 0 3 8 7 6
样例输出
0 5 2 4 6 1 3 8 7 9
#include <cstdio>
void getNums(int* p) {
for(int i = 0; i < 10; i++) {
scanf("%d", p + i);
}
}
void exchange(int* p) {
int *min = p, *max = p, tmp;
for(int i = 1; i < 10; i++) {
if(*(p + i) < *min) {
min = p + i;
} else if(*(p + i) > *max) {
max = p + i;
}
}
tmp = *p;
*p = *min;
*min = tmp;
tmp = *(p + 9);
*(p + 9) = *max;
*max = tmp;
}
void putsNums(int* p) {
for(int i = 0; i < 10; i++) {
printf("%d ", *(p + i));
}
printf("\n");
}
int main() {
int arr[10], *p;
p = arr;
getNums(p);
exchange(p);
putsNums(p);
return 0;
}