OJ lintcode 兩數(shù)之和

給一個(gè)整數(shù)數(shù)組,找到兩個(gè)數(shù)使得他們的和等于一個(gè)給定的數(shù) target铭段。
你需要實(shí)現(xiàn)的函數(shù)twoSum需要返回這兩個(gè)數(shù)的下標(biāo), 并且第一個(gè)下標(biāo)小于第二個(gè)下標(biāo)。注意這里下標(biāo)的范圍是 1 到 n,不是以 0 開頭玄叠。
注意事項(xiàng)
你可以假設(shè)只有一組答案。
您在真實(shí)的面試中是否遇到過這個(gè)題拓提?
Yes
樣例
給出 numbers = [2, 7, 11, 15], target = 9, 返回 [1, 2].

/*
class Solution {
public:
    /*
     * @param numbers : An array of Integer
     * @param target : target = numbers[index1] + numbers[index2]
     * @return : [index1+1, index2+1] (index1 < index2)
     * 時(shí)間 復(fù)雜度 O(N^2)
     */
     /*
    vector<int> twoSum(vector<int> &nums, int target) {
        // write your code here
        vector<int> res;
        for(int i=0;i<nums.size();i++){
            for(int j=i+1;j<nums.size();j++){
                if(nums[i]+nums[j]==target){
                    res.push_back(i+1);
                    res.push_back(j+1);
                    return res;
                }
            }
        }

        return res;
    }
};
*/

class Solution {
public:
    /*
    * @param numbers : An array of Integer
    * @param target : target = numbers[index1] + numbers[index2]
    * @return : [index1+1, index2+1] (index1 < index2)
    * 時(shí)間復(fù)雜度 O(N)
    * 空間復(fù)雜度 O(N)
    */
    vector<int> twoSum(vector<int> &nums, int target) {
        // write your code here
        set<int> res;
        
        //構(gòu)建一個(gè)map读恃,實(shí)現(xiàn)O(1)的元素查找
        map<int, int > m;
        for (int i = 0; i < nums.size(); i++) {
            int key = nums[i];
            int val = i;
            m[key] = val;
        }

        for (int i = 0; i < nums.size(); i++) {
            int left = target - nums[i];
            auto it=m.find(left);

            if (it != m.end()) {
                int index = i + 1;
                int left_index = m[left] + 1;
                // 排除自身等于自身的情況,比如 這樣 [1,0,-1], 0 
                if (index != left_index) {
                    res.insert(index);
                    res.insert(left_index);
                }
            }
        }

        vector<int> ret(res.begin(), res.end());
        return ret;
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末代态,一起剝皮案震驚了整個(gè)濱河市寺惫,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蹦疑,老刑警劉巖西雀,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異必尼,居然都是意外死亡蒋搜,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門判莉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來豆挽,“玉大人,你說我怎么就攤上這事券盅“锕” “怎么了?”我有些...
    開封第一講書人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵锰镀,是天一觀的道長娘侍。 經(jīng)常有香客問我,道長泳炉,這世上最難降的妖魔是什么憾筏? 我笑而不...
    開封第一講書人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮花鹅,結(jié)果婚禮上氧腰,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好古拴,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開白布箩帚。 她就那樣靜靜地躺著,像睡著了一般黄痪。 火紅的嫁衣襯著肌膚如雪紧帕。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,573評(píng)論 1 305
  • 那天桅打,我揣著相機(jī)與錄音是嗜,去河邊找鬼。 笑死油额,一個(gè)胖子當(dāng)著我的面吹牛叠纷,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播潦嘶,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼涩嚣,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了掂僵?” 一聲冷哼從身側(cè)響起航厚,我...
    開封第一講書人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎锰蓬,沒想到半個(gè)月后幔睬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡芹扭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年麻顶,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了配猫。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片浅悉。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖米母,靈堂內(nèi)的尸體忽然破棺而出轮锥,到底是詐尸還是另有隱情矫钓,我是刑警寧澤,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布舍杜,位于F島的核電站新娜,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏既绩。R本人自食惡果不足惜概龄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望饲握。 院中可真熱鬧旁钧,春花似錦吸重、人聲如沸互拾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽颜矿。三九已至寄猩,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間骑疆,已是汗流浹背田篇。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留箍铭,地道東北人泊柬。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像诈火,于是被迫代替她去往敵國和親兽赁。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

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

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗(yàn)冷守。 張土汪:刷leetcod...
    土汪閱讀 12,745評(píng)論 0 33
  • 題目 描述 給一個(gè)整數(shù)數(shù)組刀崖,找到兩個(gè)數(shù)使得他們的和等于一個(gè)給定的數(shù) target。 你需要實(shí)現(xiàn)的函數(shù)twoSum需...
    悠揚(yáng)前奏閱讀 491評(píng)論 0 0
  • Two Sum 題目: Given an array of integers, find two numbers ...
    lyoungzzz閱讀 388評(píng)論 0 0
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理拍摇,服務(wù)發(fā)現(xiàn)亮钦,斷路器,智...
    卡卡羅2017閱讀 134,657評(píng)論 18 139
  • 幾年前一個(gè)朋友曾經(jīng)帶我去過一間小眾的餐廳充活。說它小眾是因?yàn)樗徽写齱alk-in食客蜂莉,也不接受當(dāng)天訂位。每次我朋友吃...
    187014c5ff96閱讀 216評(píng)論 0 0