<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    在希臘帕爾納斯山南坡上,有一個馳名世界的戴爾波伊神托所,在它的入口處的巨石上赫然銹刻著這樣幾個大字: 認(rèn)識你自己!

    像丁香花一樣靜靜的等待

       :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      21 隨筆 :: 2 文章 :: 32 評論 :: 0 Trackbacks

    ?? 從數(shù)組中查找特定數(shù)據(jù)的最簡單辦法就是遍歷數(shù)組中所有的元素,這種查找方式稱為線性查找。對于小型數(shù)組或者是沒有經(jīng)過排序的數(shù)組的可以采用這樣的辦法,對于已經(jīng)排序的數(shù)組可以采用高效的二叉查找算法。該算法查找數(shù)組中位于中間位置的元素,并將其與查找值比較,如果兩者相等就返回該元素的索引,否則將問題化簡為查找元素的一半來處理。

    ??? class ArrayFinder{

    ? public static void print(int[] array,int middle){
    ???? for(int i=0;i<array.length;i++){
    ??????? System.out.print(array[i]);
    ??????? if(i == middle)System.out.print("*");
    ??????? System.out.print(" ");
    ???? }
    ???? System.out.println();
    ? }
    ?
    ? public static int indexOf(int[] array,int value){
    ???? int low = 0;
    ???? int high = array.length-1;
    ???? int middle;
    ???? while(low <= high){
    ??????? middle = (low + high)/2;
    ??????? print(array,middle);
    ??????? if(array[middle] == value) return middle;
    ???????
    ??????? if(value < array[middle]) //要比較的值比中間值小
    ?????????? high = middle +1;
    ??????? else
    ?????????? low = middle - 1;
    ???? }
    ???? return -1;
    ? }
    ? public static void main(String[] args){
    ??? int[] array = new int[]{1,2,3,4,6,9,12};
    ??? System.out.println("location of 13: "+indexOf(array,4));
    ? }
    ?
    }

    Result :
    D:\jcode>javac ArrayFinder.java

    D:\jcode>java ArrayFinder
    1 2 3 4* 6 9 12
    location of 13: 3

    posted on 2007-03-02 12:04 dyin 閱讀(1522) 評論(4)  編輯  收藏

    評論

    # re: 數(shù)組的二叉查找算法【java description】 2007-06-09 03:14 蠶豆
    呵呵 不太理解 真是慚愧  回復(fù)  更多評論
      

    # re: 數(shù)組的二叉查找算法【java description】 2007-09-23 14:41 vvv
    把數(shù)組的查找算法 總結(jié)一下   回復(fù)  更多評論
      

    # re: 數(shù)組的二叉查找算法【java description】 2008-05-19 20:43 何維
    如果你這個能執(zhí)行出正確的結(jié)果,那就鬼見愁了。
    if(value < array[middle]) //要比較的值比中間值小
    high = middle +1;
    else
    low = middle - 1;
    應(yīng)改為
    if(value < array[middle]) //要比較的值比中間值小
    high = middle -1;
    else
    low = middle + 1;
      回復(fù)  更多評論
      

    # re: 數(shù)組的二叉查找算法【java description】[未登錄] 2010-08-22 10:50 test
    這個是二分  回復(fù)  更多評論
      


    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 在线观看人成网站深夜免费| 精品一区二区三区免费毛片爱 | 性短视频在线观看免费不卡流畅| 亚洲大片在线观看| 免费视频成人片在线观看| 亚洲欧洲日韩不卡| 最近免费中文字幕mv电影| 亚洲熟妇无码爱v在线观看| 91免费在线播放| 中文文字幕文字幕亚洲色| 福利免费观看午夜体检区| 亚洲AV无码一区二区一二区| 国产成人免费网站在线观看| 伊人久久国产免费观看视频| 中文字幕亚洲图片| 最近最新高清免费中文字幕| 亚洲成年人电影网站| 女性自慰aⅴ片高清免费| 国产成人 亚洲欧洲| 亚洲线精品一区二区三区| 一级毛片aaaaaa免费看| 亚洲一区二区三区免费在线观看| 成人免费一区二区三区在线观看| 国产天堂亚洲精品| 久久亚洲免费视频| 最近免费中文字幕大全| 乱人伦中文视频在线观看免费| 亚洲成在人线av| 美女视频黄免费亚洲| 美女裸体无遮挡免费视频网站| 亚洲精品少妇30p| 黄在线观看www免费看| 免费无码专区毛片高潮喷水| 亚洲av无码潮喷在线观看| 欧美三级在线电影免费| 一级成人a免费视频| 久久亚洲精品无码aⅴ大香| 日本二区免费一片黄2019| 最新亚洲成av人免费看| 亚洲一线产区二线产区区| 亚洲人精品午夜射精日韩|