Leetcode之javascript解題(No33-34)

附上我的github倉庫徐块,會不斷更新leetcode解題答案满钟,提供一個思路,大家共勉

希望可以給star,鼓勵繼續(xù)更新解題思路

author: thomas

image

No34:Search for Range(Medium)

題目

Given an array of integers sorted in ascending order, find the starting and ending position of a given target value.

Your algorithm's runtime complexity must be in the order of O(log n).

If the target is not found in the array, return [-1, -1].

For example

Given [5, 7, 7, 8, 8, 10] and target value 8,
return [3, 4]. // 下標(biāo)3瞧掺,4是數(shù)組8

這道題讓我們在一個有序整數(shù)數(shù)組中尋找相同目標(biāo)值的起始和結(jié)束位置,沒如果沒有找到就返回[-1,-1]

思路

這道題讓我們在一個有序整數(shù)數(shù)組中尋找相同目標(biāo)值的起始和結(jié)束位置纹腌,而且限定了時間復(fù)雜度為O(logn)苟弛,這是典型的二分查找法的時間復(fù)雜度软棺,所以這道題我們也需要用此方法。

  • 方法一
    - 我們的思路是對原數(shù)組使用兩次二分查找法影涉,分別找出一個起始和結(jié)束位置

  • 方法二:利用二分法找到起始位置变隔,然后向右遍歷,找到邊界

代碼

  • 方法一
let arr1 = [1,1,2,2,3,4,4,7,8];
let arr = [5,7,7,8,8,10],
  target = 8;
let searchRange = function(arr, target) {
  let len = arr.length,
    res = [-1, -1];
  for (let i = 0, j = len-1; i <= j;) {
    let mid = Math.floor((i + j) / 2);
    if (arr[mid] < target) { // 先判斷小于target的情況
      i = mid + 1;
    }else {
      j = mid - 1; // 應(yīng)對剛好i = mid + 1后就指向了target值
      if (arr[mid] === target) {
        res[0] = mid; // 得到起始index
      }
    }
  }

  for (let i = 0, j = len-1; i <= j;) {
    let mid = Math.floor((i + j) / 2);
    if (arr[mid] > target) {// 先判斷大于target的情況
      j = mid - 1;
    }else {
      i = mid + 1; // 應(yīng)對剛好i = mid + 1后就指向了target值
      if (arr[mid] === target) {
        res[1] = mid; // 得到結(jié)束index
      }
    }
  }

  return res;
};
console.log(searchRange(arr,target)); // [3, 4]
  • 方法二
/**
 * 方法2
 *
 * 找到res[0]之后蟹倾,就向右遍歷匣缘,直到不是該值,就可以得到右邊界了
 * 時間復(fù)雜度沒上面的方法好
 */

let searchRange1 = function(arr, target) {
  let len = arr.length,
    res = [-1, -1];
  for (let i = 0, j = len-1; i <= j;) {
    let mid = Math.floor((i + j) / 2);
    if (arr[mid] < target) {
      i = mid + 1;
    }else {
      j = mid - 1; // 應(yīng)對剛好i = mid + 1后就指向了target值
      if (arr[mid] === target) {
        res[0] = mid; // 得到最左邊的值
      }
    }
  }
  let k;
  res[1] = res[0];
  for (k = res[0] + 1; k < len; k++) { // 找到右邊界
    if (arr[k] === target) {
      res[1] += 1;
    }
  }

  return res;
};
console.log(searchRange1([1],1)); // [0, 0]
console.log(searchRange1([2,2],2)); // [0, 1]
console.log(searchRange1([5,7,7,8,8,10],8)); // [3, 4]
console.log(searchRange1([1,3],1)); // [0, 0]
console.log(searchRange1([3,3,3],3)); // [0, 0]

注:二分法:其假設(shè)我們找到目標(biāo)值(但是有多個目標(biāo)值連在一起)

  • 1喊式、如果我們先判斷arr[mid] < target(先判斷小于target的情況),再判斷剩下的,最后得到的結(jié)果就是要找的多個目標(biāo)值target的最左邊的值
  • 2孵户、如果我們先判斷arr[mid] > target(也就是先判斷大于target的情況),再判斷剩下的,最后得到的結(jié)果就是要找的多個目標(biāo)值target的最右邊的值

No35:Search Insert Position(Easy)

題目

從給定排好順序的數(shù)組,找出給定目標(biāo)數(shù)字下標(biāo)岔留,存在則返回下標(biāo)夏哭,不存在則返回目標(biāo)數(shù)應(yīng)該插入的位置下標(biāo)。
Example 1:

Input: [1,3,5,6], 5
Output: 2

Example 2:

Input: [1,3,5,6], 2
Output: 1

Example 3:

Input: [1,3,5,6], 7
Output: 4

Example 4:

Input: [1,3,5,6], 0
Output: 0

思路

思路就是每次取中間献联,如果等于目標(biāo)即返回竖配,否則根據(jù)大小關(guān)系切去一半何址。因此算法復(fù)雜度是O(logn),空間復(fù)雜度O(1)

代碼

let arr = [1,3,5,6],
    target = 5;

let searchInset = function(arr, target) {
  let len = arr.length,
            res = 0;
  for (let i = 0, j = len -1; i <= j;) {
    let mid = Math.floor((i+j)/2);
  if (arr[mid] === target) {
            return mid;
  }
  if (arr[mid] < target) {
      i = mid + 1;
      res = mid+1; // 更新res
        }else {
        j = mid - 1;
        }
    }
    return res; //
}
console.log(searchInset(arr,target)); // 2
console.log(searchInset([1,3,5,6],2)); // 2

注意:二分法有一個好處:就是當(dāng)循環(huán)結(jié)束時:

(1)如果找到目標(biāo)元素进胯,那么就返回當(dāng)前位置

(2)如果沒有找到目標(biāo)元素用爪,那么i一定停在恰好比目標(biāo)大的index上,j一定停在恰好比目標(biāo)小的index上胁镐,所以個人比較推薦這種實現(xiàn)方式偎血。(初始i在左,j在右)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末盯漂,一起剝皮案震驚了整個濱河市颇玷,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌就缆,老刑警劉巖帖渠,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異竭宰,居然都是意外死亡空郊,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進(jìn)店門切揭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來狞甚,“玉大人,你說我怎么就攤上這事伴箩∪肜ⅲ” “怎么了鄙漏?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵嗤谚,是天一觀的道長。 經(jīng)常有香客問我怔蚌,道長巩步,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任桦踊,我火速辦了婚禮椅野,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘籍胯。我一直安慰自己竟闪,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布杖狼。 她就那樣靜靜地躺著炼蛤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蝶涩。 梳的紋絲不亂的頭發(fā)上理朋,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天絮识,我揣著相機(jī)與錄音,去河邊找鬼嗽上。 笑死次舌,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的兽愤。 我是一名探鬼主播彼念,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼浅萧!你這毒婦竟也來了国拇?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤惯殊,失蹤者是張志新(化名)和其女友劉穎酱吝,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體土思,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡务热,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了己儒。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片崎岂。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖闪湾,靈堂內(nèi)的尸體忽然破棺而出冲甘,到底是詐尸還是另有隱情,我是刑警寧澤途样,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布江醇,位于F島的核電站,受9級特大地震影響何暇,放射性物質(zhì)發(fā)生泄漏陶夜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一裆站、第九天 我趴在偏房一處隱蔽的房頂上張望条辟。 院中可真熱鬧,春花似錦宏胯、人聲如沸羽嫡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽杭棵。三九已至,卻和暖如春了牛,著一層夾襖步出監(jiān)牢的瞬間颜屠,已是汗流浹背辰妙。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留甫窟,地道東北人密浑。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像粗井,于是被迫代替她去往敵國和親尔破。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,465評論 2 348

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

  • 動態(tài)規(guī)劃 111. 爬樓梯思路類似斐波那契數(shù)列注意考慮第 0 階的特殊情況 272. 爬樓梯 II思路類似上題浇衬,只...
    6默默Welsh閱讀 2,418評論 0 1
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理懒构,服務(wù)發(fā)現(xiàn),斷路器耘擂,智...
    卡卡羅2017閱讀 134,628評論 18 139
  • 最近正在找實習(xí)胆剧,發(fā)現(xiàn)自己的算法實在是不能再渣渣,在網(wǎng)上查了一下醉冤,發(fā)現(xiàn)大家都在刷leetcode的題秩霍,于是乎本渣渣也...
    caoxian閱讀 888評論 0 2
  • 一、Java 簡介 Java是由Sun Microsystems公司于1995年5月推出的Java面向?qū)ο蟪绦蛟O(shè)計...
    子非魚_t_閱讀 4,160評論 1 44
  • 首先蚁阳,ARKit目前不支持前置攝像頭铃绒。 ARKit主要由兩部分功能組成: 利用攝像頭探索真實世界建立空間坐標(biāo)系; ...
    狂風(fēng)被雨淋閱讀 346評論 0 0