绝对值从大到小排序
冒泡排序
#include#include 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 ? ' ':'\n')); } return 0;}
参考答案
#include#include #include 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 ? ' ' : '\n')); } return 0;}