• <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
               :: 首頁 :: 新隨筆 :: 聯(lián)系 ::  :: 管理
            一、對(duì)int類型數(shù)組排序

            int num[100];

            Sample:

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

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

            二、對(duì)char類型數(shù)組排序(同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);

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

            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);

            四、對(duì)結(jié)構(gòu)體一級(jí)排序

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

            //按照data的值從小到大將結(jié)構(gòu)體排序,關(guān)于結(jié)構(gòu)體內(nèi)的排序關(guān)鍵數(shù)據(jù)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);

            五、對(duì)結(jié)構(gòu)體二級(jí)排序

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

            //按照x從小到大排序,當(dāng)x相等時(shí)按照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);

            六、對(duì)字符串進(jìn)行排序

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

            //按照結(jié)構(gòu)體中字符串str的字典順序排序

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

            qsort(s,100,sizeof(s[0]),cmp);
            功 能: 使用快速排序例程進(jìn)行排序
            用 法: void qsort(void *base, int nelem, int width, int (*fcmp)(const void *,const void *));
            各參數(shù):1 待排序數(shù)組首地址 2 數(shù)組中待排序元素?cái)?shù)量 3 各元素的占用空間大小 4 指向函數(shù)的指針,用于確定排序的順序
            程序例:
            #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));
            }





            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久精品国产福利国产秒| 国产农村妇女毛片精品久久| 久久夜色精品国产亚洲av| 性做久久久久久久久久久| 成人午夜精品无码区久久| 久久99精品久久久久久野外 | 久久久久久久免费视频| 亚洲午夜精品久久久久久人妖| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 久久久久无码中| 蜜臀av性久久久久蜜臀aⅴ麻豆| 久久99国产精品99久久| 精品久久久久久久久久中文字幕| 久久久久久久精品妇女99| 久久香蕉一级毛片| 97久久国产露脸精品国产| 88久久精品无码一区二区毛片| 18禁黄久久久AAA片| 精品无码久久久久久久动漫| 久久国产免费观看精品3| 性做久久久久久久久老女人| 国产精品99久久精品爆乳| 久久99精品久久久久子伦| 丁香色欲久久久久久综合网| 久久强奷乱码老熟女| 国产精品日韩深夜福利久久| 久久99精品久久久久子伦| 久久亚洲私人国产精品vA| 久久综合色老色| 香蕉久久久久久狠狠色| 久久久网中文字幕| 久久亚洲av无码精品浪潮| 热久久国产精品| 久久不见久久见免费视频7| 久久久久亚洲AV无码网站| 亚洲午夜久久久久久久久久| 亚洲国产精品无码成人片久久| 久久亚洲国产最新网站| 久久久久噜噜噜亚洲熟女综合| 久久精品国产黑森林| 久久久久久噜噜精品免费直播|