#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 ? ' ' : '\n'));}return 0;}qsort(x, n, sizeof(int), cmp);不了解qsort
1 回答

紫衣仙女
TA貢獻1839條經驗 獲得超15個贊
qsort快排的庫函數,cmp()是快排函數中需要調用的比較函數,也就是次排序應如何排(如是從大大小還是從小到大),此函數可缺省,也可自己寫,你給的cmp就是自己寫的意思應該是按絕對值的升序排序
添加回答
舉報
0/150
提交
取消