Leetcode 77. Combinations 39. Combination Sum

Given two integers n and k, return all possible combinations of k numbers out of 1 ... n.

For example,
If n = 4 and k = 2, a solution is:

[
  [2,4],
  [3,4],
  [2,3],
  [1,2],
  [1,3],
  [1,4], 
]

DFS輕松解決耀态,需要注意的是這個是Combination不是Permutation

vector<vector<int>> combine(int n, int k) {
    vector<vector<int>> result;
    vector<int> curr;
    
    if(n == k){
        result.push_back(curr);
        for(int i = 1;i <= k;i++){
            result[0].push_back(i);
        }
        return result;
    }
    
   
    helper(result,curr,1,n,k);
  
    return result;
    
}


void helper(vector<vector<int>>& res,vector<int>& cur,int start,int n,int k){
    if(cur.size() == k){
        res.push_back(cur);
        return ;
    }
    
    for(int i = start;i <= n ;i++){
        if(find(cur.begin(),cur.end(),i) == cur.end()){
            cur.push_back(i);
            helper(res,cur,i + 1,n,k);
            cur.pop_back();
        }    
    }
}

Given a set of candidate numbers (C) (without duplicates) and a target number (T), find all unique combinations in C where the candidate numbers sums to T.

The same repeated number may be chosen from C unlimited number of times.

Note:
All numbers (including target) will be positive integers.
The solution set must not contain duplicate combinations.
For example, given candidate set [2, 3, 6, 7] and target 7,

A solution set is: 
[
  [7],
  [2, 2, 3]
]

方法和上面那個很相似

vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
    vector<vector<int>> res;
    vector<int> cur;
    helper(res,cur,candidates,target);
    
    return res;
}

void helper(vector<vector<int>>& res,vector<int>& cur,const vector<int>& info,int sum){
    if(sum == 0){
        
        for(int i = 0;i < res.size();i++){
            if(is_permutation(res[i].begin(),res[i].end(),cur.begin())){
                return ;
            }
        }
        res.push_back(cur);
        return ;
    }   
    
    for(int i = 0;i < info.size();i++){
        if(info[i] <= sum){
            cur.push_back(info[i]);
            helper(res,cur,info,sum - info[i]);
            cur.pop_back();
        }
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子挑豌,更是在濱河造成了極大的恐慌双肤,老刑警劉巖洒擦,帶你破解...
    沈念sama閱讀 222,464評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件亚隅,死亡現(xiàn)場離奇詭異洒试,居然都是意外死亡倍奢,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評論 3 399
  • 文/潘曉璐 我一進店門垒棋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來卒煞,“玉大人,你說我怎么就攤上這事叼架∨显#” “怎么了?”我有些...
    開封第一講書人閱讀 169,078評論 0 362
  • 文/不壞的土叔 我叫張陵碉碉,是天一觀的道長柴钻。 經(jīng)常有香客問我,道長垢粮,這世上最難降的妖魔是什么贴届? 我笑而不...
    開封第一講書人閱讀 59,979評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上毫蚓,老公的妹妹穿的比我還像新娘占键。我一直安慰自己,他們只是感情好元潘,可當我...
    茶點故事閱讀 69,001評論 6 398
  • 文/花漫 我一把揭開白布畔乙。 她就那樣靜靜地躺著,像睡著了一般翩概。 火紅的嫁衣襯著肌膚如雪牲距。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,584評論 1 312
  • 那天钥庇,我揣著相機與錄音牍鞠,去河邊找鬼。 笑死评姨,一個胖子當著我的面吹牛难述,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播吐句,決...
    沈念sama閱讀 41,085評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼胁后,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了嗦枢?” 一聲冷哼從身側(cè)響起攀芯,我...
    開封第一講書人閱讀 40,023評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎文虏,沒想到半個月后敲才,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,555評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡择葡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,626評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了剃氧。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片敏储。...
    茶點故事閱讀 40,769評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖朋鞍,靈堂內(nèi)的尸體忽然破棺而出已添,到底是詐尸還是另有隱情,我是刑警寧澤滥酥,帶...
    沈念sama閱讀 36,439評論 5 351
  • 正文 年R本政府宣布更舞,位于F島的核電站,受9級特大地震影響坎吻,放射性物質(zhì)發(fā)生泄漏缆蝉。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,115評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望刊头。 院中可真熱鬧黍瞧,春花似錦、人聲如沸原杂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽穿肄。三九已至年局,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間咸产,已是汗流浹背矢否。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留锐朴,地道東北人兴喂。 一個月前我還...
    沈念sama閱讀 49,191評論 3 378
  • 正文 我出身青樓,卻偏偏與公主長得像焚志,于是被迫代替她去往敵國和親衣迷。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,781評論 2 361

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

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗酱酬。 張土汪:刷leetcod...
    土汪閱讀 12,748評論 0 33
  • 閱讀杜拉拉升職記175頁到192頁 感悟.杜拉拉升職記是我們HR經(jīng)理推薦壶谒,開始以為是小說,其實不然膳沽。職場人士必...
    汩雨貓閱讀 325評論 0 0
  • 設(shè)計模式是什么汗菜?設(shè)計模式是經(jīng)過總結(jié)、優(yōu)化的挑社,對我們經(jīng)常會碰到的一些編程問題的可重用解決方案陨界。一個設(shè)計模式并不像一個...
    靜熙老師哈哈哈閱讀 562評論 0 7
  • 【聊?感】 給好友打了兩個小時電話。聊聊自己的事情想看他的觀點痛阻。我很認同菌瘪。是因為書上這么說。他也這么說阱当。其實我也認...
    言十年閱讀 180評論 0 0
  • 03 A2:見面俏扩,s床。后來她打電話約我見面弊添,我把第一次見面的地點框架到我家里录淡。在沒見面以前她就對我很有感覺了,見...
    一條老白狼閱讀 461評論 0 0