題目描述
輸入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;
}