【LeetCode】1. 兩數(shù)之和

LeetCode 題目地址:https://leetcode-cn.com/problems/two-sum/description/

題目

給定一個整數(shù)數(shù)組和一個目標值漱办,找出數(shù)組中和為目標值的兩個數(shù)佳镜。

你可以假設(shè)每個輸入只對應(yīng)一種答案继控,且同樣的元素不能被重復利用芝加。

示例:

給定 nums = [2, 7, 11, 15], target = 9

因為 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

JavaScript:

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {

};

解答

方法一

獲取一個元素之后备畦,向后查找是否有與其相對應(yīng)的數(shù)字,如果沒有嘹吨,找下一個元素搬味。如果有,則返回蟀拷。

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
    let len = nums.length;
    for(let i = 0; i < len; i++) {
        for (let j = i + 1; j < len; j++) {
            if(nums[i] + nums[j] === target) {
                return [i,j];
                break;
            }
        }
    }
    return [];
}

方法二

獲取一個元素a碰纬,我們又知道了兩數(shù)之和target,所以我們可以通過target - a 的計算问芬,得到我們要找的另外一個數(shù)字悦析,這個時候我們在數(shù)組中查找就好。

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
    let n;
    let x;
    let len = nums.length - 1;
    for(let i = 0; i < len; i++) {
        n = target - nums[i]; // 獲取滿足條件的另一個數(shù)字
        x = nums.indexOf(n, i + 1); // 在nums數(shù)組中的第 i+1個元素之后此衅,查找是否存在n
        if(x > -1) {
            return [i, x];
        }
    }
    return [];
};

方法三

方法二 中的indexOf其實也算是遍歷了一遍數(shù)組强戴,遍歷數(shù)組是很浪費時間的,那么我們有沒有什么辦法可以快速的查找數(shù)據(jù)呢挡鞍?

為了更快速的查找改元素骑歹,我們定義一個對象obj,將key定義為數(shù)組元素墨微,value定義為該數(shù)組元素在數(shù)組中定義的下標道媚,例如:

let nums = [2, 7, 11, 15];
將 nums 改寫成 obj
let obj = {
    "2" : 0,
    "7" : 1,
    "11" : 2,
    "15" : 3
}

假設(shè)我們要數(shù)字11在nums數(shù)組中所在的位置,只需obj["11"]即可獲取翘县。

解題代碼如下:

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
    let len = nums.length;
    let n = {};
    for(let i = 0; i < len; i++) {
        if (n[ target - nums[i] ] !== undefined){
            return [n[ target-nums[i] ], i];
        }
        n[ nums[i] ] = i;
    }
    return [];
};

轉(zhuǎn)載請注明:轉(zhuǎn)自尹小芃槑

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末最域,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子锈麸,更是在濱河造成了極大的恐慌镀脂,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,383評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件忘伞,死亡現(xiàn)場離奇詭異薄翅,居然都是意外死亡,警方通過查閱死者的電腦和手機氓奈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評論 3 385
  • 文/潘曉璐 我一進店門翘魄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人探颈,你說我怎么就攤上這事熟丸。” “怎么了伪节?”我有些...
    開封第一講書人閱讀 157,852評論 0 348
  • 文/不壞的土叔 我叫張陵光羞,是天一觀的道長绩鸣。 經(jīng)常有香客問我,道長纱兑,這世上最難降的妖魔是什么呀闻? 我笑而不...
    開封第一講書人閱讀 56,621評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮潜慎,結(jié)果婚禮上捡多,老公的妹妹穿的比我還像新娘。我一直安慰自己铐炫,他們只是感情好垒手,可當我...
    茶點故事閱讀 65,741評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著倒信,像睡著了一般科贬。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上鳖悠,一...
    開封第一講書人閱讀 49,929評論 1 290
  • 那天榜掌,我揣著相機與錄音,去河邊找鬼乘综。 笑死憎账,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的卡辰。 我是一名探鬼主播胞皱,決...
    沈念sama閱讀 39,076評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼看政!你這毒婦竟也來了朴恳?” 一聲冷哼從身側(cè)響起抄罕,我...
    開封第一講書人閱讀 37,803評論 0 268
  • 序言:老撾萬榮一對情侶失蹤允蚣,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后呆贿,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體嚷兔,經(jīng)...
    沈念sama閱讀 44,265評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,582評論 2 327
  • 正文 我和宋清朗相戀三年做入,在試婚紗的時候發(fā)現(xiàn)自己被綠了冒晰。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,716評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡竟块,死狀恐怖壶运,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情浪秘,我是刑警寧澤蒋情,帶...
    沈念sama閱讀 34,395評論 4 333
  • 正文 年R本政府宣布埠况,位于F島的核電站,受9級特大地震影響棵癣,放射性物質(zhì)發(fā)生泄漏辕翰。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,039評論 3 316
  • 文/蒙蒙 一狈谊、第九天 我趴在偏房一處隱蔽的房頂上張望喜命。 院中可真熱鬧,春花似錦河劝、人聲如沸壁榕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽护桦。三九已至,卻和暖如春煎娇,著一層夾襖步出監(jiān)牢的瞬間二庵,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評論 1 266
  • 我被黑心中介騙來泰國打工缓呛, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留催享,地道東北人。 一個月前我還...
    沈念sama閱讀 46,488評論 2 361
  • 正文 我出身青樓哟绊,卻偏偏與公主長得像因妙,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子票髓,可洞房花燭夜當晚...
    茶點故事閱讀 43,612評論 2 350

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