#LeetCode:39. Combination Sum

灆洢 2019-04-04 00:30:13

利用 Backtracking 將所有可能性都列舉出來即可。

C++(12ms)

/*******************************************************/
/* LeetCode 39. Combination Sum                        */
/* Author: Maplewing [at] knightzone.studio            */
/* Version: 2019/04/04                                 */
/*******************************************************/
#include <vector>
using namespace std;

class Solution {
public:
  void getCombinationSum(vector<vector<int>> &currentAnswers, vector<int> &currentUsed, vector<int>& candidates, int startIndex, int target){
    if(target == 0){
      currentAnswers.push_back(currentUsed);
      return;
    }

    for(int i = startIndex ; i < candidates.size() ; ++i){
      if(target < candidates[i]) continue;

      currentUsed.push_back(candidates[i]);
      getCombinationSum(currentAnswers, currentUsed, candidates, i, target - candidates[i]);
      currentUsed.pop_back();
    }
  }

  vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
    vector<vector<int>> answers;
    vector<int> currentUsed;
    getCombinationSum(answers, currentUsed, candidates, 0, target);
    return answers;
  }
};

在〈“#LeetCode:39. Combination Sum”〉中有 1 則留言

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *

這個網站採用 Akismet 服務減少垃圾留言。進一步瞭解 Akismet 如何處理網站訪客的留言資料