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

            Jiang's C++ Space

            創(chuàng)作,也是一種學習的過程。

               :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::

            六、二分法查找(Binary Search)

            如何從數(shù)組里找一個元素的位置?如果排列是無序的,我們只能從頭到尾找,但如果排列是有序的,我們則可以用別的更好的方法,二分查找法就類似我們在英漢詞典里找一個單詞的方法。如下圖所示(假如我們要查找的數(shù)字是“88”):

            下面我給出了一段demo代碼,來演示二分查找法比順序查找快多少,代碼為了方便起見,初始化有序表的時候填入的數(shù)字都是均勻的,而事實上數(shù)字可以不均勻。你可以調(diào)整一下代碼中TABLE_SIZE的值,從500,調(diào)到5000,再調(diào)到10000,再調(diào)到30000……你會發(fā)覺兩者差距越來越明顯。我在第一篇的地方提到二分查找法的復雜度為Ο(logn),而順序查找的復雜度為Ο(n),當n越來越大時候,Ο(logn)的優(yōu)勢也就越來越明顯,當然了,前提是“有序”,才可用二分查找法。

            #include "stdio.h"
            #include 
            "time.h"

            #define TABLE_SIZE 50000

            //returns the position, -1 means failed.
            int SequenceSearch(int *pArray, int iArraySize, int iVal)
            {
                
            int i;
                
            for(i=0; i<iArraySize; i++)
                {
                    
            if(pArray[i]==iVal)
                        
            return i;
                }

                
            return -1;
            }

            //returns the position, -1 means failed.
            int BinarySearch(int *pArray, int iArraySize, int iVal)
            {
                
            int iLeft = 0;
                
            int iRight = iArraySize-1;
                
            while(iLeft<=iRight)
                {
                    
            int iMiddle = (iLeft+iRight)/2;
                    
            if(iVal < pArray[iMiddle])
                    {
                        iRight 
            = iMiddle-1;
                    }
                    
            else if(iVal > pArray[iMiddle])
                    {
                        iLeft 
            = iMiddle+1;
                    }
                    
            else
                        
            return iMiddle;
                }

                
            return -1;
            }

            int main(int argc, char* argv[])
            {
                
            //make the table
                int table[TABLE_SIZE];
                
            int i;
                
            for(i=0; i<TABLE_SIZE; i++)
                {
                    table[i] 
            = i*2;
                }

                clock_t ctBegin 
            = clock();
                
            //Test sequence search
                for(i=0; i<TABLE_SIZE; i++)
                {
                    SequenceSearch(table, TABLE_SIZE, i
            *2);
                }
                clock_t ctEnd 
            = clock();

                printf(
            "SequenceSearch takes %d clocks.\n", ctEnd-ctBegin);

                
            //Test binary search
                ctBegin = clock();
                
            for(i=0; i<TABLE_SIZE; i++)
                {
                    BinarySearch(table, TABLE_SIZE, i
            *2);
                }
                ctEnd 
            = clock();
                
                printf(
            "BinarySearch takes %d clocks.\n", ctEnd-ctBegin);

                
            return 0;
            }

            這篇文章是不是太簡單了點?OK,下一篇技術(shù)含量要高一點了。

            posted on 2009-10-15 10:15 Jiang Guogang 閱讀(1631) 評論(0)  編輯 收藏 引用 所屬分類: Knowledge
            精品一久久香蕉国产线看播放| 亚洲精品美女久久777777| 色欲久久久天天天综合网精品| 久久综合九色综合久99| 亚洲AV无码成人网站久久精品大| 伊人久久大香线蕉综合影院首页| 一本久道久久综合狠狠爱| 久久国产亚洲精品无码| 久久免费美女视频| 蜜臀av性久久久久蜜臀aⅴ| 99久久精品国产一区二区三区| 亚洲欧美日韩久久精品| 狠狠色婷婷综合天天久久丁香 | 久久久久人妻精品一区| 色噜噜狠狠先锋影音久久| 亚洲中文字幕无码久久精品1| 国产精品免费久久久久电影网| 日韩av无码久久精品免费| 99久久精品午夜一区二区| 久久久精品久久久久久| 久久精品国产一区二区三区日韩| 蜜桃麻豆WWW久久囤产精品| 久久久久久亚洲精品无码| 欧美国产成人久久精品| 国产亚州精品女人久久久久久 | 久久综合五月丁香久久激情| 久久精品人妻中文系列| 少妇人妻综合久久中文字幕| 久久人做人爽一区二区三区| 亚洲国产精品无码久久久秋霞2 | 国内精品久久久久久麻豆| 99re久久精品国产首页2020| 久久综合九色综合97_久久久| 很黄很污的网站久久mimi色| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 丁香五月综合久久激情| 色99久久久久高潮综合影院| 欧美亚洲国产精品久久久久| 青青草原综合久久大伊人精品| 久久久久久久尹人综合网亚洲| 久久精品不卡|