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




            久久久精品久久久久影院| 日本精品久久久中文字幕| 久久久精品国产| 久久66热人妻偷产精品9| 99久久中文字幕| 久久无码AV中文出轨人妻| 狠狠色综合网站久久久久久久高清| 色8久久人人97超碰香蕉987| 久久精品国产亚洲欧美| 色8激情欧美成人久久综合电| 亚洲国产另类久久久精品小说 | 精品国际久久久久999波多野| 欧美亚洲国产精品久久蜜芽| 一97日本道伊人久久综合影院| 婷婷久久久亚洲欧洲日产国码AV| 日本精品久久久中文字幕| 亚洲国产天堂久久久久久| 久久久无码精品亚洲日韩按摩| 久久成人精品| 久久精品无码专区免费东京热| 97香蕉久久夜色精品国产 | 性做久久久久久久久浪潮| aaa级精品久久久国产片| 少妇被又大又粗又爽毛片久久黑人| 99久久精品国内| 亚洲人成伊人成综合网久久久| 婷婷久久综合九色综合九七| 天天综合久久久网| 国内精品伊人久久久久av一坑| 久久精品国产亚洲av麻豆蜜芽| 久久久久久亚洲精品无码| 99久久免费国产精精品| 国产精品久久久久国产A级| 久久久一本精品99久久精品88| 97视频久久久| 日韩电影久久久被窝网| 国产综合久久久久| 国产高潮国产高潮久久久| 97久久国产综合精品女不卡| 久久亚洲精品成人无码网站 | 亚洲国产香蕉人人爽成AV片久久|