Combination Sum II

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

Each number in C may only be used once in the combination.

Note:

  • All numbers (including target) will be positive integers.
  • Elements in a combination (a1, a2,
    … , ak) must be in non-descending order. (ie, a1  a2 
    … ≤ ak).
  • The solution set must not contain duplicate combinations.

For example, given candidate set 10,1,2,7,6,1,5 and
target 8, 
A solution set is: 
[1, 7] 
[1, 2, 5] 
[2, 6] 
[1, 1, 6] 

#include<iostream>
#include<vector>
#include<algorithm>
#include<numeric>
#include<set>
using namespace std;

void FindcombinationSum(vector<vector<int> >&ResultVector, vector<int> &candidates, vector<int> &Oneresult, int target, int num = 0)
{
if (accumulate(Oneresult.begin(), Oneresult.end(), 0) >= target)
return;
for (int i = num; i != candidates.size();++i)
{
if (candidates[i] == candidates[i – 1] && i>num)//保证不前1个重复数字必须被使用
continue;
Oneresult.push_back(candidates[i]);
int sum = accumulate(Oneresult.begin(), Oneresult.end(), 0);
if (sum == target)
ResultVector.push_back(Oneresult);
FindcombinationSum(ResultVector, candidates, Oneresult, target, i + 1);
Oneresult.pop_back();

}
}
vector<vector<int> > combinationSum(vector<int> &candidates, int target) {
vector<vector<int> > ResultVector;
vector<int> Oneresult;
sort(candidates.begin(), candidates.end());
FindcombinationSum(ResultVector, candidates, Oneresult, target);
return ResultVector;
}

 

波比源码 – 精品源码模版分享 | www.bobi11.com
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 本站源码并不保证全部能正常使用,仅供有技术基础的人学习研究,请谨慎下载
8. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!

波比源码 » Combination Sum II

发表评论

Hi, 如果你对这款模板有疑问,可以跟我联系哦!

联系站长
赞助VIP 享更多特权,建议使用 QQ 登录
喜欢我嘛?喜欢就按“ctrl+D”收藏我吧!♡