• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 7, comments - 13, trackbacks - 0, articles - 37
               :: 首頁 :: 新隨筆 :: 聯系 ::  :: 管理

            qsort函數詳細

            Posted on 2008-08-16 15:29 歲月流逝 閱讀(370) 評論(0)  編輯 收藏 引用
            一、對int類型數組排序

            int num[100];

            Sample:

            int cmp ( const void *a , const void *b )
            {
            return *(int *)a - *(int *)b;
            }

            qsort(num,100,sizeof(num[0]),cmp);

            二、對char類型數組排序(同int類型)

            char word[100];

            Sample:

            int cmp( const void *a , const void *b )
            {
            return *(char *)a - *(int *)b;
            }

            qsort(word,100,sizeof(word[0]),cmp);

            三、對double類型數組排序(特別要注意)

            double in[100];

            int cmp( const void *a , const void *b )
            {
            return *(double *)a > *(double *)b ? 1 : -1;
            }

            qsort(in,100,sizeof(in[0]),cmp);

            四、對結構體一級排序

            struct In
            {
            double data;
            int other;
            }s[100]

            //按照data的值從小到大將結構體排序,關于結構體內的排序關鍵數據data的類型可以很多種,參考上面的例子寫

            int cmp( const void *a ,const void *b)
            {
            return ((In *)a)->data > ((In *)b)->data ? 1 : -1;
            }

            qsort(s,100,sizeof(s[0]),cmp);

            五、對結構體二級排序

            struct In
            {
            int x;
            int y;
            }s[100];

            //按照x從小到大排序,當x相等時按照y從大到小排序

            int cmp( const void *a , const void *b )
            {
            struct In *c = (In *)a;
            struct In *d = (In *)b;
            if(c->x != d->x) return c->x - d->x;
            else return d->y - c->y;
            }

            qsort(s,100,sizeof(s[0]),cmp);

            六、對字符串進行排序

            struct In
            {
            int data;
            char str[100];
            }s[100];

            //按照結構體中字符串str的字典順序排序

            int cmp ( const void *a , const void *b )
            {
            return strcmp( (*(In *)a)->str , (*(In *)b)->str );
            }

            qsort(s,100,sizeof(s[0]),cmp);
            功 能: 使用快速排序例程進行排序
            用 法: void qsort(void *base, int nelem, int width, int (*fcmp)(const void *,const void *));
            各參數:1 待排序數組首地址 2 數組中待排序元素數量 3 各元素的占用空間大小 4 指向函數的指針,用于確定排序的順序
            程序例:
            #include <iostream>
            using namespace std;
            #include <stdlib.h>
            #include <string.h>
            int compare( const void *a, const void *b);
            char * list[5]= {"cat","car","cab","cap","can"};
            int main()


            pascal 例程
            program quicksort;
            const
            {$ifndef MACOS}
            max = 100000;
            {$else}
            max = 1000; {Actually it works with 100000 also, but that might }
            {lead problems occacionally.}
            {$endif}
            type
            tlist = array[1..max] of longint;
            var
            data : tlist;

            procedure qsort(var a : tlist);
            procedure sort(l,r: longint);
            var
            i,j,x,y: longint;
            begin
            i:=l;
            j:=r;
            x:=a[(l+r) div 2];
            repeat
            while a<x do
            inc(i);
            while x<a[j] do
            dec(j);
            if not(i>j) then
            begin
            y:=a;
            a:=a[j];
            a[j]:=y;
            inc(i);
            j:=j-1;
            end;
            until i>j;
            if l<j then
            sort(l,j);
            if i<r then
            sort(i,r);
            end;
            begin
            sort(1,max);
            end;
            var
            i : longint;
            begin
            write('Creating ',Max,' random numbers between 1 and 500000');
            randomize;
            for i:=1 to max do
            data:=random(500000);
            writeln;
            writeln('Sorting...');
            qsort(data);
            writeln;
            for i:=1 to max do
            begin
            write(data:7);
            if (i mod 10)=0 then
            writeln;
            end;
            end.
            {
            int x;
            qsort((void *)list,5,sizeof(list[0]),compare);
            for (x=0;x<5;x++)
            cout<<list[x]<<endl;
            return 0;
            }
            int compare(const void *a,const void *b)
            {
            return(strcmp(*(char**)a,*(char**)b));
            }




            狠狠干狠狠久久| 精品多毛少妇人妻AV免费久久| 九九久久精品无码专区| 人妻无码久久精品| 麻豆成人久久精品二区三区免费| 色综合久久久久久久久五月 | 久久免费高清视频| 亚洲国产成人精品91久久久 | 国内精品伊人久久久久妇| 久久天天躁狠狠躁夜夜avapp| 日韩亚洲欧美久久久www综合网| 亚洲精品NV久久久久久久久久| 久久一日本道色综合久久| 久久精品国产国产精品四凭| 久久香综合精品久久伊人| 国产精品无码久久四虎| 久久香综合精品久久伊人| 性做久久久久久久久老女人| 青青草原综合久久| 久久久久亚洲av无码专区| 久久久久久久久久久免费精品| 国产99精品久久| 亚洲狠狠婷婷综合久久蜜芽| 久久97久久97精品免视看秋霞| 国产精品99精品久久免费| 亚洲午夜久久久| 一97日本道伊人久久综合影院| 97超级碰碰碰碰久久久久| 久久国产精品成人片免费| 中文字幕久久精品无码| 久久久久久久精品妇女99| 亚洲国产精品无码久久九九| 久久99精品久久久久久9蜜桃| 亚洲国产精品久久久久婷婷软件| 久久丫精品国产亚洲av不卡| 亚洲狠狠婷婷综合久久久久| 免费无码国产欧美久久18| 国产精品亚洲综合久久| 久久婷婷五月综合成人D啪| 综合久久一区二区三区| 99久久无色码中文字幕人妻|