绝对值从大到小排序
冒泡排序
#include <stdio.h> #include <math.h> int main() { int n; while (scanf_s("%d", &n) && n) { int i, j, t, s[101] = { 0 }; for (i = 0; i < n; i++) scanf_s("%d", &s[i]); for (i = 0; i < n; i++) { //冒泡排序 for (j = 0; j < n - 1 - i; j++) { if (abs(s[j]) < abs(s[j + 1])) t = s[j + 1]; s[j + 1] = s[j]; s[j] = t; } } for (i = 0; i < n; i++) printf("%d%c",s[i],(i < n -1 ? ' ':' ')); } return 0; }
参考答案
#include <math.h> #include <stdio.h> #include <stdlib.h> int cmp(const int *a, const int *b) { return abs(*b) - abs(*a); } int main(void) { int n, i, x[101]; while (scanf("%d", &n), n) { for (i = 0 ; i < n ; i++) scanf("%d", x + i); qsort(x, n, sizeof(int), cmp); for (i = 0 ; i < n ; i++) printf("%d%c", x[i], (i != n - 1 ? ' ' : ' ')); } return 0; }