• <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 歲月流逝 閱讀(374) 評論(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));
            }




            欧美久久一级内射wwwwww.| 伊人丁香狠狠色综合久久| 91精品观看91久久久久久| 久久青青草原国产精品免费| 久久996热精品xxxx| 久久久久久久久66精品片| 久久伊人五月丁香狠狠色| 精品久久久久久久无码| 久久99精品久久久久久水蜜桃| 久久精品无码一区二区app| 99精品久久精品| 亚洲人成精品久久久久| 久久久久久久波多野结衣高潮| 久久综合综合久久狠狠狠97色88| 狠狠综合久久综合中文88| 亚洲AV日韩AV永久无码久久| 国产日韩欧美久久| 情人伊人久久综合亚洲| 久久无码AV一区二区三区| 99久久精品免费观看国产| 亚洲精品美女久久777777| 色播久久人人爽人人爽人人片aV| 国产精品9999久久久久| 色综合久久中文字幕无码| 国产精品亚洲综合久久 | 99久久精品免费| 久久精品国产99久久久| 久久AV高清无码| 亚洲精品午夜国产va久久| 精品国产综合区久久久久久 | 国产精品九九久久免费视频| 久久精品国产亚洲av麻豆小说| 久久99久久99精品免视看动漫| 日日狠狠久久偷偷色综合96蜜桃 | 欧美麻豆久久久久久中文| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 亚洲精品午夜国产VA久久成人| 色综合久久88色综合天天 | 久久精品国产WWW456C0M| 久久伊人精品青青草原日本| 国产亚洲美女精品久久久2020|