線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:2624
推到 Plurk!
推到 Facebook!

[問題]qsort用在struct結構

尚未結案
plihui
初階會員


發表:88
回覆:96
積分:41
註冊:2003-07-03

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-03-28 00:27:01 IP:61.230.xxx.xxx 未訂閱
剛看過範例也如法炮製一下 但是出來的結果並沒有做排序 我的結構宣告
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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-03-28 04:14:18 IP:61.221.xxx.xxx 未訂閱
引言: 剛看過範例也如法炮製一下 但是出來的結果並沒有做排序 我的結構宣告
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);
不曉得各位看灣有解嗎?!
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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-03-29 13:01:59 IP:218.160.xxx.xxx 未訂閱
引言: [/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;
系統時間:2024-11-25 13:28:18
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!