[問題]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 做比較,然後由小到大 排列嗎? ( > >>>>>>>>> name="+(AnsiString)m[i].name+">Lines->Add("after sort"); for(int i=0; i<20; i++) { Memo1->Lines->Add(IntToStr(i)+", name="+(AnsiString)m[i].name+", diff="+FloatToStr(m[i].diff)); } } (3)請再依照自己的需求,自行修改 > < src="http://delphi.ktop.com.tw/loadfile.php?TOPICID=10003806&CC=223734"> -- Enjoy Researching & Developing -- 發表人 - RaynorPao 於 2004/03/28 21:08:59
------
-- 若您已經得到滿意的答覆,請適時結案!! -- -- 欲知前世因,今生受者是;欲知來世果,今生做者是 -- -- 一切有為法,如夢幻泡影,如露亦如電,應作如是觀 -- |
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. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |