给定一个无重复元素的数组 candidates
和一个目标数 target
,找出 candidates
中所有可以使数字和为 target
的组合。
candidates
中的数字可以无限制重复被选取。
说明:
- 所有数字(包括
target
)都是正整数。 - 解集不能包含重复的组合。
示例 1:
输入: candidates = [2,3,6,7], target = 7, 所求解集为: [ [7], [2,2,3] ]
示例 2:
输入: candidates = [2,3,5], target = 8, 所求解集为: [ [2,2,2,2], [2,3,3], [3,5] ]
解题思路:
DFS,一共三个变化量,分别是当前的target值,当前的访问位置pos,以及之前的访问数据road。
1. 先对数组排序。
2. DFS可以访问所有组合,只访问pos及其之后的数据,可以避免重复。
3. 每次访问一个数据,将数据写入road,target都要相应减小,直到为0,将road存储到res,很显然res是个全局变量(相对class Solution)。
4. 优化。pos位置的值如果大于target,那么后续都不必访问。
class Solution { public: vector<vector<int>> combinationSum(vector<int>& candidates, int target) { sort(candidates.begin(), candidates.end()); data = candidates; vector<int> road;//存储访问过的值,初始值为空 DFS(0, target, road); return res; } void DFS(int pos, int target, vector<int> road) { if (target == 0) { res.push_back(road); return; } for (int i = pos; i<int(data.size()); i++) { if (data[i] > target) return; target -= data[i]; road.push_back(data[i]); DFS(i, target, road); road.erase(road.end() - 1); target += data[i]; } } private: vector<int> data; vector<vector<int>> res; }; |