算法-二分查找

二分查找就是每次都找中間數(shù)掀泳,然后跟要查找的數(shù)對(duì)比懒熙。

比如有這樣一個(gè)數(shù)組:

var s = [1,2,3,4,5,6,7,8,9,10,104,234]; (排過序的)

你要從中間找到104的下標(biāo)罪针,怎么辦蕾殴?

我們寫一個(gè)函數(shù):


function BinarySearch(s,x){ ??

?//s為待查找數(shù)組笑撞,x為要查找的數(shù)

? ? ? ?var a = 0;

? ? ? ?var b = s.length-1;

? ? ? ?while(a<=b){ ?只要最小數(shù)不大于最大數(shù),就一直執(zhí)行(好像是廢話)

? ? ? ? ? ? ? ? var middle = parseInt((a+b)/2); ? //取數(shù)組中間下標(biāo)

? ? ? ? ? ? ? ? if (x == s[middle]) {

? ? ? ? ? ? ? ? ? ? ? ?return middle; ?//找到了钓觉,返回結(jié)果

? ? ? ? ? ? ? ? }else if(x < s[middle]){

? ? ? ? ? ? ? ? ? ? ? b = middle-1; ? ? //沒找到茴肥,將中間值作為最大值,繼續(xù)執(zhí)行

? ? ? ? ? ? ? ?}else{

? ? ? ? ? ? ? ? ? ? ? a = middle + 1; ? //沒找到荡灾,將中間值作為最小值瓤狐,繼續(xù)執(zhí)行

? ? ? ? ? ? ? }

? ? ? }

? ? ? return -1; ?//數(shù)組里沒有這個(gè)數(shù),返回-1批幌;

}


我們要找到104在數(shù)組s里所對(duì)應(yīng)的下標(biāo)础锐,就只需要調(diào)用函數(shù)

var? res = BinarySearch(s,104);


學(xué)習(xí)了二分法,來個(gè)實(shí)例:還是剛剛那個(gè)數(shù)組:

var s = [1,2,3,4,5,6,7,8,9,10,104,234];

要從里面找到2個(gè)數(shù)荧缘,要求他們的相加等于110皆警,怎么做?

先說思想截粗,二分法是找一個(gè)數(shù)信姓,題目要求是找二個(gè)數(shù),怎么辦绸罗?我們要把問題轉(zhuǎn)化到找一個(gè)數(shù)上意推,遍歷數(shù)組s,每次遍歷的時(shí)候得到其中一個(gè)數(shù)s[i],然后去找另外一個(gè)數(shù)珊蟀,我們要找相加等于110的數(shù)菊值,那另外一個(gè)數(shù)其實(shí)就等于110-s[i],說到這里是不是已經(jīng)明白了系洛?

沒明白不要緊俊性,貼代碼,請(qǐng)看下面這個(gè)函數(shù):



function searchTwoNum(s,x){ //傳數(shù)組s 和 兩個(gè)數(shù)之和x

? ? var dic;

? ? for(var i = 0; i < s.length;i++){

? ? ? ? var a = s[i]; ? //假設(shè)它是其中一個(gè)數(shù)

? ? ? ? var b = x - s[i]; ?//假設(shè)a的假設(shè)成立描扯,那b就是另一個(gè)數(shù)

? ? ? ? var n = BinarySearch(s,b); //判斷是不是有b定页,有的話就說明a的假設(shè)成立了

? ? ? ? if (n != -1) { //上面說了n==-1的時(shí)候?qū)嶋H上就是沒找到,所以不等于-1時(shí)就找到了

? ? ? ? ? ? dic = {i:i,n:n,a:a,b:b};

? ? ? ? ? ? break; //找到了就不找了绽诚,跳出去

? ? ? ? }

? ? }

? ? return dic;

}


調(diào)用該函數(shù)典徊,就可以找到要找的數(shù):

var dic = searchTwoNum(s,110);

console.log(dic);

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末杭煎,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子卒落,更是在濱河造成了極大的恐慌羡铲,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,525評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件儡毕,死亡現(xiàn)場離奇詭異也切,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)腰湾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門雷恃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人费坊,你說我怎么就攤上這事倒槐。” “怎么了附井?”我有些...
    開封第一講書人閱讀 164,862評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵讨越,是天一觀的道長。 經(jīng)常有香客問我永毅,道長把跨,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,728評(píng)論 1 294
  • 正文 為了忘掉前任卷雕,我火速辦了婚禮节猿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘漫雕。我一直安慰自己,他們只是感情好峰鄙,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評(píng)論 6 392
  • 文/花漫 我一把揭開白布浸间。 她就那樣靜靜地躺著,像睡著了一般吟榴。 火紅的嫁衣襯著肌膚如雪魁蒜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,590評(píng)論 1 305
  • 那天吩翻,我揣著相機(jī)與錄音兜看,去河邊找鬼。 笑死狭瞎,一個(gè)胖子當(dāng)著我的面吹牛细移,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播熊锭,決...
    沈念sama閱讀 40,330評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼弧轧,長吁一口氣:“原來是場噩夢啊……” “哼雪侥!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起精绎,我...
    開封第一講書人閱讀 39,244評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤速缨,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后代乃,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體旬牲,經(jīng)...
    沈念sama閱讀 45,693評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評(píng)論 3 336
  • 正文 我和宋清朗相戀三年搁吓,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了原茅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,001評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡擎浴,死狀恐怖员咽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情贮预,我是刑警寧澤贝室,帶...
    沈念sama閱讀 35,723評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站仿吞,受9級(jí)特大地震影響滑频,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜唤冈,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評(píng)論 3 330
  • 文/蒙蒙 一峡迷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧你虹,春花似錦绘搞、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至董饰,卻和暖如春蒿褂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背卒暂。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評(píng)論 1 270
  • 我被黑心中介騙來泰國打工啄栓, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人也祠。 一個(gè)月前我還...
    沈念sama閱讀 48,191評(píng)論 3 370
  • 正文 我出身青樓昙楚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親齿坷。 傳聞我的和親對(duì)象是個(gè)殘疾皇子桂肌,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評(píng)論 2 355

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