Kata02:只有10%程序員能寫對(duì)的二分查找

CodeKata02地址

繼續(xù)做CodeKata肌稻。

第二個(gè)Kata要求很簡(jiǎn)單:二分查找。現(xiàn)在不懂二分查找的程序員恐怕不多了吧?不過二分查找還有一段趣事。

只有10%程序員能寫對(duì)二分查找

這個(gè)結(jié)論出自著名的《編程珠璣》荤堪,相關(guān)內(nèi)容可以看這里:http://www.csdn.net/article/a/2010-04-23/218099

文中讓我感觸最深的一句話是“ in an age when programmers spend more time plugging libraries together than writing actual code, core algorithmic skills are likely if anything to have declined”,千萬不要成為一個(gè)只會(huì)堆砌庫(kù)的泥瓦工枢赔。

let's rock

當(dāng)然逞力,作為一個(gè)Kata,絕對(duì)不可能只要求二分查找這么簡(jiǎn)單糠爬,作者要求的是寫出5種不同的二分查找寇荧。

前兩種地球人都能想到:遞歸和迭代。

我們的代碼太丑了执隧,放一個(gè)寫完之后Google出來的代碼吧揩抡,大概是我們代碼的一半長(zhǎng):

function binary_search_iterative(value, a) {
    var lo = 0, hi = a.length - 1, mid;
    while (lo <= hi) {
        mid = Math.floor((lo+hi)/2);
        if (a[mid] > value)
            hi = mid - 1;
        else if (a[mid] < value)
            lo = mid + 1;
        else
            return mid;
    }
    return -1;
}

對(duì)了户侥,我們用的是JavaScript。

這段代碼的重點(diǎn)是hi = mid - 1lo = mid + 1峦嗤,這兩句中的+1-1有兩個(gè)作用:避免死循環(huán)以及優(yōu)化性能蕊唐,至于為什么能做到這兩點(diǎn),請(qǐng)大家自己思考一下~

Kata中給出了一些測(cè)試用例烁设,我們寫了一個(gè)測(cè)試函數(shù)方便使用:

var test = function(fn) {
    var test_data = [
        [-1, [3, []]],
        [-1, [3, [1]]],
        [0, [1, [1]]],
        [0, [1, [1, 3, 5]]],
        [1, [3, [1, 3, 5]]],
        [2, [5, [1, 3, 5]]],
        [-1, [0, [1, 3, 5]]],
        [-1, [2, [1, 3, 5]]],
        [-1, [4, [1, 3, 5]]],
        [-1, [6, [1, 3, 5]]],
        [0, [1, [1, 3, 5, 7]]],
        [1, [3, [1, 3, 5, 7]]],
        [2, [5, [1, 3, 5, 7]]],
        [3, [7, [1, 3, 5, 7]]],
        [-1, [0, [1, 3, 5, 7]]],
        [-1, [2, [1, 3, 5, 7]]],
        [-1, [4, [1, 3, 5, 7]]],
        [-1, [6, [1, 3, 5, 7]]],
        [-1, [8, [1, 3, 5, 7]]],
    ]
    for (var i in test_data) {
        console.log(test_data[i][0] == fn.apply(this, test_data[i][1]))  // 把a(bǔ)rray當(dāng)作參數(shù)傳入函數(shù)
    }
}

test(binary_search_iterative)

使用的時(shí)候直接test(your_function)就可以了替梨。

兩種搞定,第三種文中給出了提示:用函數(shù)式編程装黑。

函數(shù)式編程

函數(shù)式編程到底是什么呢副瀑?我們看了一些資料,仍然沒有理解恋谭,不過大體上來說糠睡,函數(shù)式編程是一種思想,并不是說一定要用haskell疚颊、scala才能進(jìn)行函數(shù)式編程狈孔,很多語言都可以,就像設(shè)計(jì)模式和語言無關(guān)一樣材义。

函數(shù)式編程水太深均抽,我們找了一些不錯(cuò)的學(xué)習(xí)資料,準(zhǔn)備等學(xué)會(huì)之后再來實(shí)現(xiàn)其掂。

這三本都是很不錯(cuò)的函數(shù)式編程學(xué)習(xí)材料到忽,之所以選擇haskell,是為了逼自己用函數(shù)式編程的思維來編程清寇。不過最近應(yīng)該是沒時(shí)間學(xué)習(xí)了喘漏,先存下來,之后一定會(huì)學(xué)华烟。

我沒有特殊的二分查找技巧

第三種也勉強(qiáng)算搞定吧翩迈,這第四第五種可真是難倒我們了,兩個(gè)人想了兩天也沒搞定盔夜,最后只得作罷负饲。如果大家有想法的話一定要告訴我們啊喂链!

虎頭蛇尾

這個(gè)Kata總覺得不爽返十,似乎是太簡(jiǎn)單了,又似乎是自己會(huì)的太少了椭微,有一種使不上力的感覺洞坑。不過通過這個(gè)Kata記住了一種二分查找的簡(jiǎn)潔實(shí)現(xiàn)方法,還找到了函數(shù)式編程的學(xué)習(xí)資料蝇率,也算有所收獲吧迟杂。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末刽沾,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子排拷,更是在濱河造成了極大的恐慌侧漓,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件监氢,死亡現(xiàn)場(chǎng)離奇詭異布蔗,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)浪腐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門纵揍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人牛欢,你說我怎么就攤上這事∠危” “怎么了傍睹?”我有些...
    開封第一講書人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)犹菱。 經(jīng)常有香客問我拾稳,道長(zhǎng),這世上最難降的妖魔是什么腊脱? 我笑而不...
    開封第一講書人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任访得,我火速辦了婚禮,結(jié)果婚禮上陕凹,老公的妹妹穿的比我還像新娘悍抑。我一直安慰自己,他們只是感情好杜耙,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開白布搜骡。 她就那樣靜靜地躺著,像睡著了一般佑女。 火紅的嫁衣襯著肌膚如雪记靡。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,079評(píng)論 1 285
  • 那天团驱,我揣著相機(jī)與錄音摸吠,去河邊找鬼。 笑死嚎花,一個(gè)胖子當(dāng)著我的面吹牛寸痢,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播紊选,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼轿腺,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼两嘴!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起族壳,我...
    開封第一講書人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤憔辫,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后仿荆,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體贰您,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年拢操,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了锦亦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡令境,死狀恐怖杠园,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情舔庶,我是刑警寧澤抛蚁,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站惕橙,受9級(jí)特大地震影響瞧甩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜弥鹦,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一肚逸、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧彬坏,春花似錦朦促、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至混滔,卻和暖如春洒疚,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背坯屿。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工油湖, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人领跛。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓乏德,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子喊括,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容