本题要求编写程序,输入n个实数,使用指针引用的方式将它们按从大到小的顺序排列。
输入格式:
输入第一行给出一个正整数n(2≤n≤10),输入第二行给出n个实数,其间以空格分隔。
输出格式:
输出从大到小排好序的n个数(保留2位小数),每个数之间空一格,行末没有空格。
输入样例:
在这里给出一组输入。例如:
5
3.2 5.4 6.12 2.51 4.23
输出样例:
在这里给出相应的输出。例如:
6.12 5.40 4.23 3.20 2.51
代码:
#include<stdio.h>
#include<stdlib.h>
double order(double *p, int num,double *k);
int main() {
double a[10], b[10];
int num, i;
scanf("%d", &num);
for (i = 0; i < num; i++) {
scanf("%lf", &a[i]);
}
order(a, num,b);
for (i = 0; i < num; i++) {
if (i == num - 1) {
printf("%.2lf", b[num - 1]);
}
else {
printf("%.2lf ", b[i]);
}
}
return 0;
}
double order(double* p, int num,double*k) {
int cnt = 0;
int i, t;
for (i = 0; i < num; i++) {
for (t = 0; t < num; t++) {
if ( * (p + i) < *(p + t)) {
cnt++;
}
}
*(k + cnt) = *(p + i);
cnt = 0;
}
}