• <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中成員

            国产精品久久久久…| 久久精品青青草原伊人| 999久久久免费精品国产| 久久精品国产秦先生| 精品视频久久久久| 熟妇人妻久久中文字幕| 精品久久国产一区二区三区香蕉 | 亚洲?V乱码久久精品蜜桃 | 国内精品久久久久影院优| 久久精品视频免费| 久久无码高潮喷水| 精品久久久久久99人妻| 久久久久无码精品国产| 亚洲?V乱码久久精品蜜桃| 99精品久久精品| 久久精品国产亚洲av麻豆蜜芽| 久久99国产精一区二区三区| 亚洲欧美国产精品专区久久| 热re99久久精品国产99热| 77777亚洲午夜久久多喷| 久久国产成人午夜aⅴ影院| 狠狠色丁香久久综合五月| 一97日本道伊人久久综合影院| 久久综合久久综合久久| 97久久国产露脸精品国产| 欧美日韩久久中文字幕| 婷婷久久综合九色综合绿巨人 | 亚洲欧美国产日韩综合久久| 69久久精品无码一区二区| 国产成人无码精品久久久性色| 性高湖久久久久久久久AAAAA| 狠狠精品久久久无码中文字幕| 国产综合久久久久| www.久久热.com| 老司机国内精品久久久久| 久久精品中文字幕久久| 狠色狠色狠狠色综合久久| 久久久91精品国产一区二区三区| 国产产无码乱码精品久久鸭| 久久亚洲中文字幕精品有坂深雪| 国产成人精品白浆久久69|