• <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 歲月流逝 閱讀(373) 評論(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无码麻豆| 久久久国产乱子伦精品作者| 欧洲人妻丰满av无码久久不卡| 色诱久久久久综合网ywww| 久久久亚洲精品蜜桃臀| 久久夜色精品国产网站| 欧美亚洲日本久久精品| 久久这里有精品视频| 77777亚洲午夜久久多喷| 久久99精品久久久久久hb无码| 国产成人香蕉久久久久| 亚洲欧洲久久av| 国产成人久久久精品二区三区| 亚洲国产高清精品线久久| 久久久久亚洲AV无码永不| 一级做a爰片久久毛片毛片| 国产精品va久久久久久久| 狠狠色婷婷久久综合频道日韩| 国内精品久久久久久久久电影网| 天天躁日日躁狠狠久久| 亚洲精品无码久久千人斩| 三级片免费观看久久| 久久精品国产精品青草| 久久美女网站免费| 丁香狠狠色婷婷久久综合| 97精品伊人久久久大香线蕉 | 久久久久久A亚洲欧洲AV冫| 久久香蕉一级毛片| 久久久无码一区二区三区| 国产A级毛片久久久精品毛片| 亚洲色欲久久久久综合网| 久久精品国产亚洲Aⅴ蜜臀色欲| 国产精品美女久久久m| 久久青青草原亚洲av无码app| 亚洲AV成人无码久久精品老人| 久久精品国产2020| av无码久久久久久不卡网站| 无码人妻久久一区二区三区免费 | 大伊人青草狠狠久久| 久久久久国产精品熟女影院| 九九精品99久久久香蕉|