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

不會(huì)飛的鳥(niǎo)

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

線性查找和二分查找

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

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

程序1:線型查找法實(shí)現(xiàn)對(duì)某個(gè)數(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:二分法查找法實(shí)現(xiàn)對(duì)某個(gè)數(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ù)組中最后一個(gè)數(shù)n,那么搜索從0開(kāi)始,一直檢索到n,要經(jīng)過(guò)n次遍歷,時(shí)間復(fù)雜度:O(n),而二分查找法中如果查找關(guān)鍵字小于數(shù)組中間的元素,就查找數(shù)組的頭半部分,否則查找數(shù)組的后半部分,時(shí)間復(fù)雜度:O(log2n),如果在指定子數(shù)組中還沒(méi)有查找到關(guān)鍵字,就再把子數(shù)組折半,反復(fù)進(jìn)行這種查找,直到要查找的關(guān)鍵字等于子數(shù)組中間的元素,或沒(méi)有找到關(guān)鍵字為止。在最壞的情況下,用二分法查找有1024個(gè)元素的數(shù)組也只需要比較10次,即用2除1024,連續(xù)除10次得到1為止,如果有1048576(2的20次方)個(gè)元素,用二分法只要比較20次就可以找到要查找的元素,而用簡(jiǎn)單的線型查找則需要進(jìn)行2的20次方查找,可見(jiàn)二分法比線型查找法的效率要高得多,對(duì)10億哥元素的數(shù)組來(lái)說(shuō),平均比較5億次和30次簡(jiǎn)直是天壤之別!所以掌握二分法對(duì)在龐大的數(shù)組庫(kù)處理是很有效的!

posted on 2011-06-27 13:48 不會(huì)飛的鳥(niǎo) 閱讀(1737) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   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>
            亚洲男人的天堂在线观看| 一本色道久久综合亚洲精品婷婷| 亚洲国产专区| 亚洲网站视频| 亚洲电影有码| 亚洲精品久久7777| 国产精品久久久久一区二区三区共 | 亚洲激情中文1区| 国产亚洲亚洲| 国产性色一区二区| 国内精品一区二区| 激情综合网激情| 精久久久久久| 亚洲激情视频在线| 在线亚洲精品| 亚洲欧美日韩国产另类专区| 亚洲三级影片| 亚洲欧美一区在线| 香蕉久久夜色精品国产| 午夜日韩在线| 欧美激情精品久久久久| 日韩午夜免费视频| 欧美一区二区在线看| 女仆av观看一区| 99精品国产99久久久久久福利| 亚洲一级特黄| 欧美午夜精品一区二区三区| 欧美成人性生活| 国产乱码精品一区二区三| 国产亚洲成av人片在线观看桃| 亚洲在线日韩| 美女视频一区免费观看| 欧美高清成人| 亚洲一二三区在线| 欧美高清成人| 亚洲国产高清一区| 欧美在线播放视频| 亚洲综合精品自拍| 国产精品老牛| 性久久久久久| 欧美亚洲一区二区在线观看| 欧美日韩在线播放一区| 夜久久久久久| 最新国产成人在线观看| 欧美一区午夜精品| 韩国精品一区二区三区| 久久精品欧洲| 久久久国产成人精品| 在线免费观看视频一区| 美女在线一区二区| 欧美激情第六页| 亚洲综合国产| 久久电影一区| 亚洲精品无人区| 欧美风情在线| 欧美日韩精品一区二区天天拍小说| 亚洲国产欧美日韩| 夜夜爽av福利精品导航 | 亚洲视频在线免费观看| 99日韩精品| 一区二区亚洲| 亚洲自拍偷拍色片视频| 国内精品免费在线观看| 亚洲国产黄色片| 国产精品美女久久福利网站| 久久午夜视频| 欧美福利影院| 一区二区三区精品视频在线观看| 欧美日韩精品久久| 久热精品视频在线免费观看| 欧美激情第8页| 欧美成人蜜桃| 狠狠色综合网| 午夜精品久久久久久久| 亚洲欧美国产精品专区久久| 欧美日韩国产精品| 亚洲国产成人在线| 在线观看国产精品淫| 欧美一级在线视频| 国产日韩亚洲欧美精品| 亚洲视频在线观看免费| 99国产精品国产精品毛片| 久久午夜国产精品| 欧美激情一区在线| 亚洲人体一区| 欧美高清在线精品一区| 91久久精品网| 欧美一区二区精品在线| 国产日韩欧美不卡在线| 亚洲自拍高清| 免费观看在线综合色| 亚洲黄色成人网| 欧美日韩国产影院| 午夜精品久久久久久久99黑人| 久久国产精品久久w女人spa| 国产日韩欧美中文| 免费欧美日韩| 在线综合亚洲| 麻豆成人在线| 欧美视频精品在线观看| 亚洲激情专区| 国产午夜精品全部视频在线播放| 亚洲人成网站在线播| 亚洲永久免费精品| 美女精品自拍一二三四| 国语自产精品视频在线看| 久久精品99国产精品| 一本色道久久综合亚洲精品不卡| 久久爱www久久做| 亚洲视频免费| 最新日韩在线| …久久精品99久久香蕉国产| 国产精品毛片va一区二区三区| 欧美专区在线观看一区| 一区二区三区精品久久久| 亚洲国产乱码最新视频| 久久久国产精品亚洲一区 | 欧美了一区在线观看| 久久九九免费视频| 亚洲欧美日韩一区| 亚洲欧美精品| 亚洲欧美日韩一区在线| 亚洲免费伊人电影在线观看av| 日韩亚洲欧美在线观看| 亚洲精品视频一区| 亚洲毛片在线| 在线视频精品一| 亚洲一区国产视频| 亚洲自拍偷拍视频| 久久综合久色欧美综合狠狠| 国产原创一区二区| 中文欧美字幕免费| 欧美在线视频播放| 欧美成在线视频| 国产精品在线看| 91久久精品www人人做人人爽 | 伊人久久亚洲热| 亚洲欧洲在线一区| 国产性猛交xxxx免费看久久| 99精品免费网| 欧美专区在线观看一区| 欧美激情综合亚洲一二区| 国产精品区一区二区三区| 黄色亚洲大片免费在线观看| 99国产精品久久久久老师| 午夜精品久久久久久久99黑人| 久久久久.com| 国产精品99久久久久久宅男| 久久久久高清| 国产欧美日韩不卡| 久久精品亚洲精品国产欧美kt∨| 久久婷婷国产综合精品青草| 国产精品亚发布| 亚洲欧美日韩国产精品| 一本色道久久加勒比精品| 欧美国产日韩在线| 日韩视频二区| 亚洲破处大片| 欧美不卡在线视频| 永久免费视频成人| 久久久久九九九| 欧美在线不卡| 亚洲高清在线观看| 亚洲激情不卡| 欧美性jizz18性欧美| 亚洲欧美资源在线| 亚洲欧美美女| 亚洲人成网站999久久久综合| 欧美激情1区2区3区| 欧美乱人伦中文字幕在线| 亚洲欧美视频在线| 欧美在线一区二区三区| 亚洲靠逼com| 亚洲私人影院| 亚洲经典三级| 亚洲一区二区三区乱码aⅴ| 又紧又大又爽精品一区二区| 亚洲国产日韩欧美在线99| 国产老女人精品毛片久久| 免费在线亚洲| 国产精品欧美风情| 亚洲高清自拍| 久热精品在线| 亚洲视频在线观看网站| 欧美成人网在线| 国产综合色产在线精品| 亚洲精品一区在线| 一区二区亚洲精品| 亚洲视频国产视频| 91久久久一线二线三线品牌| 久久噜噜亚洲综合| 国产精品电影观看| 亚洲美女精品成人在线视频| 韩国三级电影久久久久久| 宅男噜噜噜66国产日韩在线观看| 亚洲国产欧美国产综合一区| 香蕉av福利精品导航| 欧美在线免费观看亚洲| 国产精品久久久久免费a∨| 亚洲美女在线一区|