青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

不會飛的鳥

2010年12月10日 ... 不鳥他們!!! 我要用自己開發(fā)的分布式文件系統(tǒng)、分布式調(diào)度系統(tǒng)、分布式檢索系統(tǒng), 做自己的搜索引擎!!!大魚有大志!!! ---楊書童

線性查找和二分查找

問題:數(shù)組查找它和數(shù)組排序一樣是重要的計算應(yīng)用之一,電話公司根據(jù)姓氏查找,能容易的找到用戶的電話號碼和繳費情況,在學(xué)校成績管理系統(tǒng)可以根據(jù)學(xué)生的學(xué)號,很容易就能查找到學(xué)生的成績及相關(guān)資料,查找在生活中的應(yīng)用是十分廣泛,數(shù)據(jù)排序是一個令人感興趣的問題,這里深入理解兩種最基本的算法:線型查找和二分法查找。

         線型查找:把數(shù)組的每一個元素和檢索關(guān)鍵字比較,安順序從第一個元素一直檢索到要查找的元素,平均來說,程序要把查找關(guān)鍵字與一半數(shù)組元素進行比較。二分法查找:線型查找法對小型數(shù)組和未排序的數(shù)組效果較好,但是,對于大型數(shù)據(jù)來說,線型查找法效率較低。如果已經(jīng)對數(shù)組排序,那么可以使用速度很快的二分法查找.

程序1:線型查找法實現(xiàn)對某個數(shù)的查找!
#include<stdio.h>
#include<stdlib.h>
#define Size 100
int         main()   
{
            int linearSearch(int a[],int key,int size);
            int         a[Size],i,searchKey,element;
            for(i=0;i<Size-1;i++)
            a[i]=2*i;
            printf("Enter integer search key:\n");
            scanf("%d",&searchKey);
            element=linearSearch(a,searchKey,Size);
            if(element!=-1)
                printf("Found value in element %d !\n",element);
            else
                printf("Value is not found!\n");
            system("pause");
}   

int linearSearch(int array[],int key,int size)
{
           int j;
           for(j=0;j<Size-1;j++)
           if(array[j]==key)
              return j;
           return -1;
}

程序2:二分法查找法實現(xiàn)對某個數(shù)的查找!
#include<stdio.h>
#include<stdlib.h>
#define Size 15
int         main()   
{
            int binarySearch(int [],int,int,int);
            void printHeader(void);
            void printRow(int [],int,int,int);
            int a[Size],i,key,element;
            for(i=0;i<=Size-1;i++)
                a[i]=2*i;
            printf("Enter a number between 0 and 28:");
            scanf("%d",&key);
            printHeader();
            element=binarySearch(a,key,0,Size-1);
            if(element!=-1)
                printf("\n%d found in array element %d !\n",key,element);
            else
                printf("\n%d is not found!\n",key);
         
            system("pause");
}  

void printHeader()
{
            int i;
            printf("\nSubscripts:\n");
            for(i=0;i<=Size-1;i++)
                printf("%3d",i);
            printf("\n");
            for(i=1;i<=4*Size;i++)
                printf("-");
            printf("\n");
}

int binarySearch(int array[],int searchKey,int low,int high)
{
           void printRow(int array[],int low,int middle,int high);
           int middle;
           while(low<=high)
           {
               middle=(low+high)/2;
               printRow(array,low,middle,high);
               if(searchKey==array[middle])
                  return middle;
               else if(searchKey<array[middle])
                  high=middle-1;
               else
                  low=middle+1;
           }
           return -1;
}
void printRow(int array[],int low,int middle,int high)
{
            int i;
            for(i=0;i<=Size-1;i++)
                if(i<low||i>high)
                   printf(" ");
                else if(i==middle)
                   printf("%3d*",array[i]);
                else
                   printf("%3d",array[i]);
            printf("\n");
}


           效率分析:線型查找擺脫了數(shù)組排序的約束,不足之處是不適合大型數(shù)據(jù)查找,并且查找方法比較老套,如果要找的數(shù)在數(shù)組中最后一個數(shù)n,那么搜索從0開始,一直檢索到n,要經(jīng)過n次遍歷,時間復(fù)雜度:O(n),而二分查找法中如果查找關(guān)鍵字小于數(shù)組中間的元素,就查找數(shù)組的頭半部分,否則查找數(shù)組的后半部分,時間復(fù)雜度:O(log2n),如果在指定子數(shù)組中還沒有查找到關(guān)鍵字,就再把子數(shù)組折半,反復(fù)進行這種查找,直到要查找的關(guān)鍵字等于子數(shù)組中間的元素,或沒有找到關(guān)鍵字為止。在最壞的情況下,用二分法查找有1024個元素的數(shù)組也只需要比較10次,即用2除1024,連續(xù)除10次得到1為止,如果有1048576(2的20次方)個元素,用二分法只要比較20次就可以找到要查找的元素,而用簡單的線型查找則需要進行2的20次方查找,可見二分法比線型查找法的效率要高得多,對10億哥元素的數(shù)組來說,平均比較5億次和30次簡直是天壤之別!所以掌握二分法對在龐大的數(shù)組庫處理是很有效的!

posted on 2011-06-27 13:48 不會飛的鳥 閱讀(1740) 評論(0)  編輯 收藏 引用


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


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美在线3区| 欧美aa国产视频| 欧美自拍偷拍午夜视频| 欧美激情精品久久久六区热门 | 欧美大片在线观看| 洋洋av久久久久久久一区| 久久精品在线| 国产日韩综合一区二区性色av| 中国成人亚色综合网站| 亚洲激情综合| 麻豆精品在线视频| 极品尤物一区二区三区| 久久人人爽人人爽爽久久| 欧美怡红院视频一区二区三区| 国产免费成人在线视频| 欧美在线观看视频一区二区三区| 亚洲性线免费观看视频成熟| 欧美日韩国产色视频| 99天天综合性| 99re国产精品| 国产精品美女久久久久久久| 午夜久久久久久久久久一区二区| 亚洲视频欧美视频| 国产欧美精品在线播放| 欧美综合国产| 另类人畜视频在线| 亚洲欧洲日本国产| 亚洲毛片在线| 国产精品腿扒开做爽爽爽挤奶网站 | 狠狠综合久久av一区二区小说 | 午夜精品久久久久影视| 午夜精品一区二区三区四区| 国外成人在线| 欧美高清视频www夜色资源网| 老妇喷水一区二区三区| 9人人澡人人爽人人精品| 亚洲视频在线一区观看| 国产综合久久| 亚洲美女视频| 国产字幕视频一区二区| 亚洲国产一区二区在线| 国产精品色婷婷| 老司机免费视频一区二区| 欧美大片国产精品| 欧美一区亚洲一区| 欧美成人网在线| 欧美一区影院| 欧美激情性爽国产精品17p| 午夜性色一区二区三区免费视频| 欧美影视一区| 国产精品99久久久久久宅男| 欧美一级大片在线免费观看| 91久久国产综合久久蜜月精品| 宅男噜噜噜66国产日韩在线观看| 国产一区二区三区精品久久久| 欧美高清视频免费观看| 国产精品午夜视频| 亚洲欧洲精品一区二区| 韩国v欧美v日本v亚洲v| 亚洲精品视频在线观看免费| 国产区在线观看成人精品| 亚洲国产日韩一区| 国产一区二区三区自拍| 亚洲一区二区综合| 久久综合伊人77777| 亚洲免费小视频| 嫩草影视亚洲| 久久久午夜视频| 国产精品大片wwwwww| 欧美国产日本在线| 国产综合精品一区| 亚洲网站在线看| 亚洲三级电影全部在线观看高清| 午夜伦欧美伦电影理论片| 一区二区三区国产| 欧美国产一区二区在线观看| 久久一区亚洲| 国产亚洲亚洲| 香蕉久久国产| 久久xxxx| 国产欧美韩国高清| 亚洲午夜视频| 亚洲一区二区三区中文字幕在线| 欧美成人综合| 亚洲国产一区二区a毛片| 亚洲第一精品在线| 久久久久久久久综合| 久久精品一二三| 国产欧美在线观看一区| 亚洲影院色无极综合| 亚洲自拍偷拍视频| 欧美无乱码久久久免费午夜一区| 亚洲人成高清| 一区二区三区日韩欧美| 欧美日产在线观看| 日韩一级黄色大片| 亚洲一区二区高清| 国产精品久久久久天堂| 亚洲一二三区在线观看| 午夜在线观看免费一区| 国产丝袜一区二区三区| 欧美伊人久久久久久久久影院| 久久精品免费播放| 国产一区二区三区最好精华液| 欧美一区二区三区久久精品| 久久久蜜臀国产一区二区| 在线成人黄色| 欧美高清在线精品一区| 日韩视频在线观看国产| 亚洲欧美另类在线| 国产手机视频精品| 蜜臀99久久精品久久久久久软件| 亚洲国产成人不卡| 在线亚洲电影| 国产偷久久久精品专区| 久久夜色精品亚洲噜噜国产mv| 亚洲盗摄视频| 亚洲摸下面视频| 伊人久久综合| 欧美性猛交视频| 欧美专区亚洲专区| 亚洲人屁股眼子交8| 欧美一区在线看| 亚洲第一页中文字幕| 欧美日韩亚洲成人| 久久国产精品99精品国产| 亚洲区欧美区| 久久蜜桃av一区精品变态类天堂| 亚洲精品久久嫩草网站秘色 | 欧美视频在线观看 亚洲欧| 久久影视三级福利片| 在线观看三级视频欧美| 欧美日韩国产成人在线观看| 午夜久久一区| 亚洲欧洲美洲综合色网| 久久国产主播精品| 99精品国产在热久久下载| 国产美女精品在线| 欧美国产成人精品| 欧美在线视频导航| 99精品视频免费| 欧美成人激情视频| 欧美在线观看网址综合| 亚洲精品午夜精品| 国外成人在线视频| 国产精品视频精品| 欧美日韩国产色综合一二三四 | 欧美一区2区三区4区公司二百| 欧美激情五月| 久久女同互慰一区二区三区| 亚洲一区二区三区在线播放| 欧美天堂亚洲电影院在线观看 | 久久精品av麻豆的观看方式| 亚洲国产成人av| 欧美综合激情网| 亚洲色图制服丝袜| 永久久久久久| 国产女人18毛片水18精品| 欧美精品一区二区三区很污很色的 | 在线观看一区二区精品视频| 亚洲精品一区二区三区蜜桃久| 欧美高清在线一区| 久久精品免费播放| 亚洲一级特黄| 亚洲精品中文字| 亚洲国产精品va在线观看黑人| 久久精品一区二区三区四区| 亚洲免费视频在线观看| 一本大道久久a久久综合婷婷| 亚洲二区三区四区| 今天的高清视频免费播放成人 | 欧美一区二区三区视频在线观看| 亚洲免费电影在线观看| 亚洲黄网站在线观看| 在线观看日韩av电影| 在线不卡欧美| 91久久精品国产91久久| 亚洲国产高清aⅴ视频| 在线成人免费视频| 在线日韩视频| 91久久国产自产拍夜夜嗨| 亚洲伦理精品| 这里是久久伊人| 亚洲欧美日韩一区在线观看| 亚洲综合清纯丝袜自拍| 欧美一级免费视频| 久久久91精品国产一区二区精品| 久久青草欧美一区二区三区| 麻豆国产va免费精品高清在线| 免费看黄裸体一级大秀欧美| 免费日韩视频| 亚洲另类在线一区| 亚洲欧美视频在线| 亚洲一区二区三区在线视频| 99热免费精品| 中文日韩欧美| 亚洲免费网址| 久久久久国产成人精品亚洲午夜| 久久国产日韩| 欧美xart系列高清|