• <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 閱讀(1205) 評論(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中成員

            AA级片免费看视频久久| 一本久久知道综合久久| 久久综合九色综合久99 | 久久久久久亚洲精品不卡| 精品久久久久久久中文字幕| 欧洲国产伦久久久久久久| 99久久精品免费看国产一区二区三区| 亚洲AV无一区二区三区久久| 久久精品免费一区二区三区| 中文字幕久久精品 | 久久夜色精品国产亚洲| 久久精品国产亚洲AV无码娇色| 久久97久久97精品免视看秋霞| 久久国产色av免费看| 国产亚洲美女精品久久久| 欧洲成人午夜精品无码区久久| 久久久久人妻一区精品| 久久99久久99精品免视看动漫| 要久久爱在线免费观看| 国产精品无码久久久久| 久久久九九有精品国产| 一本一道久久综合狠狠老| 人妻丰满?V无码久久不卡| 青青草原综合久久| 久久99国产乱子伦精品免费| 狠狠色综合网站久久久久久久高清 | 欧美麻豆久久久久久中文| 99久久久国产精品免费无卡顿| 久久久久人妻一区二区三区| 久久性精品| 精品国产综合区久久久久久| 久久亚洲国产午夜精品理论片| 久久综合给合久久国产免费 | 三级片免费观看久久| 日本精品久久久中文字幕| 久久综合欧美成人| 久久99国产亚洲高清观看首页| 久久青青草原精品国产| 国内精品久久久久久久97牛牛| 77777亚洲午夜久久多喷| 久久99国产亚洲高清观看首页 |