167. 兩數(shù)之和 II - 輸入有序數(shù)組

1.題目

給你一個(gè)下標(biāo)從 1 開始的整數(shù)數(shù)組 numbers 机蔗,該數(shù)組已按 非遞減順序排列 闰非,請(qǐng)你從數(shù)組中找出滿足相加之和等于目標(biāo)數(shù) target 的兩個(gè)數(shù)膘格。如果設(shè)這兩個(gè)數(shù)分別是 numbers[index1] 和 numbers[index2] ,則 1 <= index1 < index2 <= numbers.length 财松。

以長(zhǎng)度為 2 的整數(shù)數(shù)組 [index1, index2] 的形式返回這兩個(gè)整數(shù)的下標(biāo) index1 和 index2瘪贱。

你可以假設(shè)每個(gè)輸入 只對(duì)應(yīng)唯一的答案 ,而且你 不可以 重復(fù)使用相同的元素辆毡。

你所設(shè)計(jì)的解決方案必須只使用常量級(jí)的額外空間菜秦。

示例 1:
輸入:numbers = [2,7,11,15], target = 9
輸出:[1,2]
解釋:2 與 7 之和等于目標(biāo)數(shù) 9 。因此 index1 = 1, index2 = 2 胚迫。返回 [1, 2] 喷户。

示例 2:
輸入:numbers = [2,3,4], target = 6
輸出:[1,3]
解釋:2 與 4 之和等于目標(biāo)數(shù) 6 。因此 index1 = 1, index2 = 3 访锻。返回 [1, 3] 褪尝。

示例 3:
輸入:numbers = [-1,0], target = -1
輸出:[1,2]
解釋:-1 與 0 之和等于目標(biāo)數(shù) -1 。因此 index1 = 1, index2 = 2 期犬。返回 [1, 2] 河哑。

提示:
2 <= numbers.length <= 3 * 104
-1000 <= numbers[i] <= 1000
numbers 按 非遞減順序 排列
-1000 <= target <= 1000
僅存在一個(gè)有效答案

2.雙指針

初始時(shí)兩個(gè)指針?lè)謩e指向第一個(gè)元素位置和最后一個(gè)元素的位置。每次計(jì)算兩個(gè)指針指向的兩個(gè)元素之和龟虎,
并和目標(biāo)值比較璃谨。如果兩個(gè)元素之和等于目標(biāo)值,則發(fā)現(xiàn)了唯一解鲤妥。如果兩個(gè)元素之和小于目標(biāo)值佳吞,
則將左側(cè)指針右移一位。如果兩個(gè)元素之和大于目標(biāo)值棉安,則將右側(cè)指針左移一位底扳。移動(dòng)指針之后,重復(fù)上述操作贡耽,直到找到答案衷模。
使用雙指針的實(shí)質(zhì)是縮小查找范圍。那么會(huì)不會(huì)把可能的解過(guò)濾掉蒲赂?答案是不會(huì)阱冶。
由于題目確保有唯一的答案,因此使用雙指針一定可以找到答案滥嘴。

3.代碼

object Solution {
   def twoSum(numbers: Array[Int], target: Int): Array[Int] = {
    var left = 0
    var right = numbers.length-1
    while (left<right){
      if(numbers(left)+numbers(right)==target) {
          return Array[Int](left + 1,right+1)
      }
      else if(numbers(left)+numbers(right)>target){
        right = right - 1
      }
      else {
        left=left+1
      }
    }
    Array[Int](-1,-1)
  }
}

3.1.復(fù)雜度分析

  • 時(shí)間復(fù)雜度:O(n)木蹬,其中 n 是數(shù)組的長(zhǎng)度。兩個(gè)指針移動(dòng)的總次數(shù)最多為 n 次若皱。

  • 空間復(fù)雜度:O(1)届囚。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末有梆,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子意系,更是在濱河造成了極大的恐慌,老刑警劉巖饺汹,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蛔添,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡兜辞,警方通過(guò)查閱死者的電腦和手機(jī)迎瞧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)逸吵,“玉大人凶硅,你說(shuō)我怎么就攤上這事∩ㄖ澹” “怎么了足绅?”我有些...
    開封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)韩脑。 經(jīng)常有香客問(wèn)我氢妈,道長(zhǎng),這世上最難降的妖魔是什么段多? 我笑而不...
    開封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任首量,我火速辦了婚禮,結(jié)果婚禮上进苍,老公的妹妹穿的比我還像新娘加缘。我一直安慰自己,他們只是感情好觉啊,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開白布拣宏。 她就那樣靜靜地躺著,像睡著了一般柄延。 火紅的嫁衣襯著肌膚如雪蚀浆。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天搜吧,我揣著相機(jī)與錄音市俊,去河邊找鬼。 笑死滤奈,一個(gè)胖子當(dāng)著我的面吹牛摆昧,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蜒程,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼绅你,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼伺帘!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起忌锯,我...
    開封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤伪嫁,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后偶垮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體张咳,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年似舵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了脚猾。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡砚哗,死狀恐怖龙助,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蛛芥,我是刑警寧澤提鸟,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站常空,受9級(jí)特大地震影響沽一,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜漓糙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一铣缠、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧昆禽,春花似錦蝗蛙、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至盗棵,卻和暖如春壮韭,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背纹因。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工喷屋, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人瞭恰。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓屯曹,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子恶耽,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

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