[問題]qsort用在struct結構 |
尚未結案
|
plihui
初階會員 ![]() ![]() 發表:88 回覆:96 積分:41 註冊:2003-07-03 發送簡訊給我 |
剛看過範例也如法炮製一下
但是出來的結果並沒有做排序
我的結構宣告
typedef struct { AnsiString name; double diff; }Result;我的sort的依據是將 Result中的diff(diff值介於0~1) int sort_function( const void *cmp1, const void *cmp2) { Result *R1,*R2; R1 = (Result* )cmp1; R2 = (Result *)cmp2; int big=(R1->diff > R2->diff)?1:0; return big; }主程式先假設result[20]正確存入名字和diff qsort(result,20, sizeof(Result), sort_function);不曉得各位看灣有解嗎?! |
RaynorPao
版主 ![]() ![]() ![]() ![]() ![]() ![]() 發表:139 回覆:3622 積分:7025 註冊:2002-08-12 發送簡訊給我 |
引言: 剛看過範例也如法炮製一下 但是出來的結果並沒有做排序 我的結構宣告typedef struct { AnsiString name; double diff; }Result;我的sort的依據是將 Result中的diff(diff值介於0~1)int sort_function( const void *cmp1, const void *cmp2) { Result *R1,*R2; R1 = (Result* )cmp1; R2 = (Result *)cmp2; int big=(R1->diff > R2->diff)?1:0; return big; }主程式先假設result[20]正確存入名字和diffqsort(result,20, sizeof(Result), sort_function);不曉得各位看灣有解嗎?! plihui 你好: (1)不太了解你的意思,你是想要以 struct 中的 diff 做比較,然後由小到大 排列嗎?
------
-- 若您已經得到滿意的答覆,請適時結案!! -- -- 欲知前世因,今生受者是;欲知來世果,今生做者是 -- -- 一切有為法,如夢幻泡影,如露亦如電,應作如是觀 -- |
brook
資深會員 ![]() ![]() ![]() ![]() ![]() 發表:57 回覆:323 積分:371 註冊:2002-07-12 發送簡訊給我 |
引言: [/code] int sort_function( const void *cmp1, const void *cmp2) { Result *R1,*R2; R1 = (Result* )cmp1; R2 = (Result *)cmp2; int big=(R1->diff > R2->diff)?1:0; return big; } [/code]我覺得big值要包含1,0,-1共3個值,而你的值只有1和0,有所以你必須加一個條件,當R1小於diff 時 big = -1; |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |