首页 > 其他 > 详细

[LeetCode] Combination Sum

时间:2015-06-18 00:40:46      阅读:244      评论:0      收藏:0      [点我收藏+]

Well, a typical backtracking problem. Make sure you are clear with the following three problems:

  1. What is a partial solution and when is it finished? --- In this problem, the partial solution is a combination and it is finished once it sums to target.
  2. How to find all the partial solutions? --- In the following code, I use a for-loop to traverse all the possible elements in candidates.
  3. When to make recursive calls? --- In the following code, once an element is added to the partial solution, we call the function to generate the remaining elements recursively.

Of course, remember to recover to the previous status once a partial solution is done. In the following code, line 18 (comb.pop_back()) is for this purpose.

The following should be self-explanatory :)

 1 class Solution {
 2 public:
 3     vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
 4         sort(candidates.begin(), candidates.end());
 5         vector<vector<int> > res;
 6         vector<int> comb;
 7         combination(candidates, 0, target, comb, res);
 8         return res;
 9     }
10 private:
11     void combination(vector<int>& candidates, int start, int remain, vector<int>& comb, vector<vector<int> >& res) {
12         if (!remain) {
13             res.push_back(comb);
14             return;
15         }
16         for (int i = start; i < (int)candidates.size(); i++) {
17             if (remain >= candidates[i]) {
18                 comb.push_back(candidates[i]);
19                 combination(candidates, i, remain - candidates[i], comb, res);
20                 comb.pop_back();
21             }
22         }
23     }
24 };

 

[LeetCode] Combination Sum

原文:http://www.cnblogs.com/jcliBlogger/p/4584712.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!