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

隨筆-19  評(píng)論-21  文章-0  trackbacks-0
     二分查找法(Binary search algorithm)是一個(gè)很常見(jiàn)的算法,從<編程珠璣>里再次看到時(shí)又有新的收獲。
     直接看代碼吧,下面是常見(jiàn)的實(shí)現(xiàn)代碼:
    
int binary_search(int *a, int num, int t)
{
    
int start = 0, end = num - 1;
    
    
while(end >= start){
        
int middle = (start + end) / 2;
        
int tmp = a[middle];
        
if(tmp < t){
            start 
= middle + 1;
        }
else if(tmp > t){
            end 
= middle - 1;
        }
else{
            
return middle;
        }
    }

    
return -1;
}   

      優(yōu)化后的代碼為(這個(gè)優(yōu)化的思想也挺好的,不知道有沒(méi)有一套系統(tǒng)的方法來(lái)思考出這個(gè)優(yōu)化思路):
     
int binary_search(int *a, int num, int t)
{
    
int low = -1, high = num - 1;
    
    
while(low + 1 != high){
        
int middle = (low + high) / 2;
        
if(a[middle] < t){
            low 
= middle;
        }
else{
            high 
= middle;
        }
    }
    
    
if(a[high] != t)
        
return -1;
    
else
        
return high;
}
 
     如果直接看這段代碼,有可能不知道是怎么回事。但是運(yùn)用書(shū)中提到的“程序驗(yàn)證”的方法后,原理就顯而易見(jiàn)了,修改后的代碼為:

 1 int binary_search(int *a, int num, int t)
 2 {
 3     int low = -1, high = num - 1;
 4     
 5     //invariant: low < high && a[low] < t && a[high] >= t
 6     while(low + 1 != high){
 7         int middle = (low + high) / 2==>  int middle = low + (high - low) / 2;   //防止溢出
 8         if(a[middle] < t){
 9             low = middle;
10         }else{
11             high = middle;
12         }
13     }   
14    //assert: low +1 = high && a[low] < t && a[high] >= t
15   
16     if(a[high] != t)
17         return -1;
18     else
19         return high;
20 }
21 

      “程序驗(yàn)證” 的思想可以簡(jiǎn)述為:不管是驗(yàn)證一個(gè)函數(shù),還是一條語(yǔ)句,一個(gè)控制結(jié)構(gòu)(循環(huán),if分支等),都可以采用兩個(gè)斷言(前置條件和后置條件)來(lái)達(dá)到這個(gè)目的。前置條件是在執(zhí)行該處代碼之前就應(yīng)該成立的條件,后置條件的正確性在執(zhí)行完該處代碼后必須得到保證。(ps: 斷言也算是一種驗(yàn)證的手段)

  上面這段代碼的原理是給定一段區(qū)間 (low, high] ,如果満足 a[low] < t  && a[high] >=t && high = low + 1,那么有兩種情況存在:1. a[high] = t ; 2.與t相等的元素不存在。由于數(shù)組a 肯定滿足條件a[low] < t  && a[high] >=t,所以該算法要做的就是把區(qū)間 (-1, num -1] 縮小到(low, low+1]。  
      1. 在執(zhí)行代碼6~17行時(shí),始終保證low < high && a[low] < t && a[high] >= t 成立。
  
2. 在執(zhí)行完6~17行后,肯定滿足條件a[low] < t  && a[high] >=t && high = low + 1,因?yàn)檠h(huán)退出的條件是 high = low + 1,而該循環(huán)始終保證上面第1條。
  經(jīng)過(guò)這樣的分析后,我們能對(duì)程序的正確性有更好的掌握,同時(shí)程序也更易理解。

參考:
  1. 基本上摘自<編程珠璣>,很不錯(cuò)的一本書(shū),讓我對(duì)算法有了新的思考,以前只是看看算法導(dǎo)論如何實(shí)現(xiàn)的,沒(méi)有思考該算法是如何想出來(lái)的,有沒(méi)有更簡(jiǎn)單的算法(思考的過(guò)程類似劉未鵬的<知其所以然(續(xù))>),要堅(jiān)持這個(gè)思考過(guò)程需要很多功夫與時(shí)間,但效果也很明顯,能對(duì)算法有更好的掌握。
posted on 2011-06-18 15:02 hex108 閱讀(2881) 評(píng)論(3)  編輯 收藏 引用 所屬分類: Algorithm

評(píng)論:
# re: 二分查找 -- 來(lái)自編程珠璣 2011-06-24 10:11 | tank
你的程序有錯(cuò),你知道不??  回復(fù)  更多評(píng)論
  
# re: 二分查找 -- 來(lái)自編程珠璣 2011-06-24 15:53 | hex108
@tank
請(qǐng)指教,謝謝~  回復(fù)  更多評(píng)論
  
# re: 二分查找 -- 來(lái)自編程珠璣[未登錄](méi) 2012-01-18 04:02 | terry
1 2 2 3 查找2,是不是不對(duì)?  回復(fù)  更多評(píng)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            鲁大师影院一区二区三区| 国产亚洲欧美日韩精品| 在线亚洲欧美| 夜夜嗨av一区二区三区| 亚洲免费高清| 亚洲小视频在线观看| 亚洲在线黄色| 久久精品二区| 欧美激情1区2区| 欧美日韩国产首页| 国产精品你懂得| 一区二区三区在线看| 极品尤物一区二区三区| 亚洲欧洲一二三| 久久精品91久久香蕉加勒比| 久久亚洲综合网| 亚洲欧洲另类| 欧美一区二区三区精品电影| 免费观看在线综合| 国产精品一区2区| 亚洲日本成人| 久久国产精品一区二区| 亚洲黑丝在线| 欧美自拍丝袜亚洲| 欧美日韩一区二区三区视频| 国内自拍视频一区二区三区| 亚洲精品综合精品自拍| 欧美在线亚洲一区| 亚洲黄色在线看| 欧美一区二区三区免费看| 欧美激情综合在线| 国内一区二区三区| 午夜久久电影网| 亚洲经典自拍| 久久综合亚州| 国产精自产拍久久久久久| 1000精品久久久久久久久 | 尤物在线观看一区| 亚洲综合精品自拍| 亚洲精品久久久久久下一站| 久久久www成人免费精品| 国产精品视频午夜| 99精品欧美一区| 欧美激情2020午夜免费观看| 欧美一区二区观看视频| 国产精品99免视看9| 日韩亚洲在线| 亚洲第一主播视频| 久久视频在线视频| 国产资源精品在线观看| 欧美一区日韩一区| 亚洲午夜女主播在线直播| 欧美日韩国产小视频在线观看| 极品少妇一区二区三区精品视频| 久久久久久久尹人综合网亚洲| 亚洲一本大道在线| 国产精品久久一卡二卡| 亚洲欧美日韩精品一区二区| 一区二区三区视频观看| 国产精品国产成人国产三级| 亚洲你懂的在线视频| 亚洲网站视频福利| 国产免费亚洲高清| 久久国产精品网站| 久久国产精品久久久久久| 国产亚洲一区二区三区在线播放| 欧美一级日韩一级| 午夜在线电影亚洲一区| 国产婷婷色一区二区三区四区| 欧美呦呦网站| 国产欧美日韩精品一区| 国产日韩欧美在线播放| 欧美一区二区三区免费大片| 亚洲欧美精品一区| 国产专区一区| 欧美sm重口味系列视频在线观看| 久久综合导航| 一本色道久久精品| 亚洲在线一区| 一区在线电影| 亚洲黄色高清| 国产精品久久久久久久久久久久久久| 亚洲欧美日韩国产中文| 久久精品国产第一区二区三区| 亚洲国产成人久久综合| 亚洲毛片一区| 国产欧美一区二区三区在线老狼| 久久精品91久久久久久再现| 久久综合九色99| 亚洲私人影吧| 久久久久久久97| 一区二区三区日韩欧美| 欧美一级视频精品观看| 亚洲精品一区二区三区不| 亚洲自拍偷拍福利| 亚洲精品国产精品乱码不99按摩| 亚洲视频在线看| 亚洲国产精品国自产拍av秋霞| 亚洲美女啪啪| 伊人成人在线视频| 亚洲天堂偷拍| 亚洲国产午夜| 欧美一激情一区二区三区| 99在线精品视频在线观看| 欧美在线日韩| 亚洲欧美网站| 欧美黄免费看| 美女露胸一区二区三区| 国产精品久久久久久模特| 欧美激情在线播放| 国自产拍偷拍福利精品免费一| 亚洲狼人精品一区二区三区| 伊人色综合久久天天五月婷| 亚洲一区二区视频| 一本久久精品一区二区| 久久免费黄色| 久久精品国产亚洲精品 | 久久亚洲视频| 久久精品女人天堂| 国产精品视频| 99精品视频免费全部在线| 亚洲人被黑人高潮完整版| 久久九九热免费视频| 欧美一区二区网站| 国产精品久久久91| 夜夜爽www精品| 日韩午夜黄色| 欧美大片免费| 亚洲黄色av| 一本到12不卡视频在线dvd| 欧美国产精品一区| 亚洲黄色高清| 艳妇臀荡乳欲伦亚洲一区| 欧美精品久久天天躁| 性做久久久久久| 夜夜躁日日躁狠狠久久88av| 久久婷婷国产综合国色天香| 久久久久久久久岛国免费| 国产麻豆成人精品| 欧美一区二区精美| 久久视频在线免费观看| 国产一区二区三区久久久久久久久| 亚洲一区二区三区精品视频| 亚洲综合色婷婷| 国产精品午夜国产小视频| 亚洲欧美日韩专区| 久久青草久久| 亚洲黄色成人网| 欧美人与禽猛交乱配视频| 一本一道久久综合狠狠老精东影业| 一本久久a久久精品亚洲| 欧美午夜精品| 欧美一级电影久久| 免费看成人av| 日韩性生活视频| 国产精品久久久久久久久免费 | 美女精品自拍一二三四| 欧美成人激情视频| 亚洲精品在线一区二区| 欧美视频在线免费看| 午夜一区不卡| 欧美黄污视频| 亚洲一区二区欧美| 国内精品模特av私拍在线观看| 久久综合色天天久久综合图片| 91久久极品少妇xxxxⅹ软件| 亚洲香蕉网站| 一区二区视频免费完整版观看| 欧美激情va永久在线播放| 在线综合亚洲欧美在线视频| 久久久蜜臀国产一区二区| a4yy欧美一区二区三区| 国产欧美日韩一级| 欧美激情一区二区三区不卡| 午夜精品久久久久久久蜜桃app| 欧美成人自拍| 亚洲欧美日韩一区在线观看| 在线日韩中文| 国产精品久久久久久久午夜| 久久久免费精品| 在线亚洲美日韩| 亚洲高清视频在线观看| 久久九九国产精品| 亚洲中午字幕| 亚洲精品在线三区| 伊人夜夜躁av伊人久久| 国产精品资源在线观看| 欧美日韩国产美女| 久久一区欧美| 欧美亚洲一区| 99视频一区二区三区| 欧美成va人片在线观看| 欧美在线视频二区| 亚洲影院色在线观看免费| 亚洲人成网站影音先锋播放| 国产一区二区三区的电影| 国产精品久久久久久久午夜| 欧美日韩不卡在线| 欧美成人精品1314www| 久久久久久久一区|