• <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>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            qsort與bsearch的cmp(轉)

            Posted on 2010-09-07 15:07 Prayer 閱讀(1194) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            qsort函數聲明如下:

            void qsort(void *base, size_t nmemb, size_t size, int(*compar)(const void *, const void *));

            參數說明如下:
            base: 要排序的數組
            nmemb: 數組中的元素數目
            size: 每個數組元素占用內存空間,可使用sizeof獲得
            compar: 比較兩個數組元素的比較函數。本比較函數的第一個參數值小于、等于、大于第二參數值時,本比較函數的返回值應分別小于、等于、大于零。

            也就說你要實現一個這樣的函數:
            int cmp(const void *a, const void *b)
            如果a > b,返回>0
            如果a == b, 返回0
            如果a < b,返回<0
            這里的a和b的關系僅僅是邏輯上的,并不是值比較,所以排序的可以不僅僅是數字,還可以是字符。

             

            bsearch函數聲明如下:

            void *bsearch(const void *key, const void *base, size_t *nelem,
            size_t width, int(*fcmp)(const void *, const *));

            參數的意思和qsort的差不多,區別在于:
            1. qsort用來排序,bsearch用二分法來查找元素
            2. bsearch中的base必須是升序排列的數組!!!
            3. 如果數組里有重復的答案,則bsearch會返回其中一個的地址 (具體返回哪一個不確定)
            4. bsearch有五個自變量,第一個是要找的東西,剩下的跟qsort一模一樣
            5. bsearch如果沒找到所求則回傳NULL ,否則回傳該元素被找到的地址(void *)

            c函數qsort()和bsearch()的用法
            使用qsort()排序 并 用 bsearch()搜索是一個比較常用的組合,使用方便快捷。
            qsort 的函數原型是void __cdecl qsort ( void *base, size_t num, size_t width, int (__cdecl *comp)(const void *, const void* ) )

            其中base是排序的一個集合數組,num是這個數組元素的個數,width是一個元素的大小,comp是一個比較函數。

            比如:對一個長為1000的數組進行排序時,int a[1000]; 那么base應為a,num應為 1000,width應為 sizeof(int),comp函數隨自己的命名。

            qsort(a,1000,sizeof(int ),comp);

            其中comp函數應寫為:

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

            而關于bsearch() ,他和qsort的用法基本一樣,只是他的返回值是一個指向找到的單位元素的一個指針,另外他多了一個參數,是一個指向查找元素的一個指針。

            比如:從上面例子中的結構體數組中查找一個字符串:

            str *locate;
            char buffer[30]="abc";
            locate=(str*)bsearch(buffer,strin,total,sizeof(str),com);

            int com(const void *a,const void *b)
            {
            return strcmp( (char*)a, ((str*)b)->str2 );
            }

            注意這里cmp與qsotr的有所不同。

            qsort 和bsearch的cmp函數不同的
            qsort 比較的時dict 數組的兩個成員
            bsearch比較的時key 和dict中成員

            精品多毛少妇人妻AV免费久久 | 久久香综合精品久久伊人| 久久综合伊人77777| 伊人久久大香线蕉无码麻豆| 欧美激情一区二区久久久| 精品熟女少妇av免费久久| 久久精品女人天堂AV麻| 久久久久久久久久久久久久| 国产精品久久国产精麻豆99网站| 国产精品狼人久久久久影院 | 大美女久久久久久j久久| 亚洲精品无码久久毛片| 久久夜色精品国产亚洲| 亚洲国产成人久久一区WWW| 91精品国产综合久久婷婷| 亚洲性久久久影院| 精品久久久久久国产牛牛app| 亚洲精品国产美女久久久| 久久精品国产一区二区电影| 国产精品无码久久久久久| 亚洲欧美一级久久精品| 久久精品夜色噜噜亚洲A∨| 丰满少妇人妻久久久久久| 一本色道久久88精品综合| 亚洲欧美精品一区久久中文字幕 | 亚洲精品成人久久久| 久久综合丁香激情久久| 97久久超碰成人精品网站| 无码人妻少妇久久中文字幕蜜桃| 久久夜色撩人精品国产| 久久久久久毛片免费看| 久久精品国产国产精品四凭| 亚洲综合久久综合激情久久| 久久99久久99小草精品免视看| 色狠狠久久AV五月综合| 亚洲va久久久噜噜噜久久| 亚洲中文字幕无码久久2020 | 精品久久久久久久国产潘金莲| 久久久久国产视频电影| 久久婷婷五月综合成人D啪| 久久亚洲电影|