亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

leecode 解題總結:39. Combination Sum

2019-11-10 16:51:46
字體:
來源:轉載
供稿:網友
#include <iostream>#include <stdio.h>#include <vector>#include <algorithm>using namespace std;/*問題: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, 分析:這是程序員面試金典的一道題目。求組成數的所有組合。應該是用遞歸做。之前是n分的硬幣用25,10,5,1的硬幣表示分別枚舉i * denom <= total時,i從0到k的情況,然后遞歸做2 3 6 7此題應該也是用這種方式輸入:4(數組元素個數) 7(目標值)2 3 6 74 62 3 6 72 72 6輸出:7,2 2 36,3 3,2 2 2no result關鍵:1 前半部分求解結果,前半部分 與 后半部分結果 進行笛卡爾積 即為最終結果int curCandidate = candidates.at(curCandidateIndex);vector<vector<int>> results;//后半部分遞歸求解結果vector<int> result;//前半部分求解結果,前半部分 與 后半部分結果 進行笛卡爾積 即為最終結果for(int i = 0 ; i * curCandidate <= target ; i++){	result.clear();//清空上一次結果	for(int j = 0 ; j < i ; j++)	{		result.push_back(curCandidate);	}	results = combineSum(candidates , target -  i * curCandidate , curCandidateIndex + 1 );//得到多個結果需要和當前結果進行笛卡爾積拼接	int size = results.size();	//進行笛卡爾積拼接	for(int k = 0 ; k < size ; k++)	{		results.at(k).insert(results.at(k).end() , result.begin() , result.end());//插入到后面,前面是最小部分		totalResults.push_back(results.at(k));	}	//如果當前直接等于結果集i * curCandidate = target,直接壓入結果中	if(i * curCandidate == target)	{		totalResults.push_back(result);	}}return totalResults;*/bool compare(int a, int b){	return a > b;}class Solution {public:	vector<vector<int>> combineSum(vector<int>& candidates, int target , int curCandidateIndex)	{		vector< vector<int> > totalResults;		if(candidates.empty() || target <= 0 || curCandidateIndex < 0 || curCandidateIndex >= candidates.size())		{			return totalResults;		}		int curCandidate = candidates.at(curCandidateIndex);		vector<vector<int>> results;//后半部分遞歸求解結果		vector<int> result;//前半部分求解結果,前半部分 與 后半部分結果 進行笛卡爾積 即為最終結果		for(int i = 0 ; i * curCandidate <= target ; i++)		{			result.clear();//清空上一次結果			for(int j = 0 ; j < i ; j++)			{				result.push_back(curCandidate);			}			results = combineSum(candidates , target -  i * curCandidate , curCandidateIndex + 1 );//得到多個結果需要和當前結果進行笛卡爾積拼接			int size = results.size();			//進行笛卡爾積拼接			for(int k = 0 ; k < size ; k++)			{				results.at(k).insert(results.at(k).end() , result.begin() , result.end());//插入到后面,前面是最小部分				totalResults.push_back(results.at(k));			}			//如果當前直接等于結果集i * curCandidate = target,直接壓入結果中			if(i * curCandidate == target)			{				totalResults.push_back(result);			}		}		return totalResults;	}    vector<vector<int>> combinationSum(vector<int>& candidates, int target) {        //必須確保候選值從大到小排序		sort(candidates.begin() , candidates.end() , compare );		int curCandidateIndex = 0;		vector<vector<int>> results = combineSum(candidates, target , curCandidateIndex);		return results;    }};void PRint(vector<vector<int>>& results){	if(results.empty())	{		cout << "no result" << endl;		return;	}	int size = results.size();	for(int i = 0 ; i < size ; i++)	{		int len = results.at(i).size();		for(int j = 0 ; j < len ; j++)		{			cout << results.at(i).at(j) << " ";		}		cout << ",";	}	cout << endl;}void process(){	int num;	vector<int> nums;	int target;	int value;	Solution solution;	vector< vector<int> > results;	while(cin >> num >> target)	{		nums.clear();		for(int i = 0 ; i < num ; i++)		{			cin >> value;			nums.push_back(value);		}		results = solution.combinationSum(nums , target);		print(results);	}}int main(int argc , char* argv[]){	process();	getchar();	return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产精品资源| 久久天天躁狠狠躁夜夜躁2014| 亚洲iv一区二区三区| 久热爱精品视频线路一| 青草热久免费精品视频| 久久香蕉精品香蕉| 91精品在线观| 亚洲精品xxx| 亚洲情综合五月天| 色悠悠久久88| 国产剧情久久久久久| 国产精品视频自拍| 91麻豆国产语对白在线观看| 亚洲精品免费网站| 97碰碰碰免费色视频| 精品国产老师黑色丝袜高跟鞋| 美女啪啪无遮挡免费久久网站| 欧美性受xxxx黑人猛交| 亚洲aⅴ男人的天堂在线观看| 国内精品小视频在线观看| 日本亚洲精品在线观看| 色无极亚洲影院| 日本一区二区在线免费播放| 日产精品久久久一区二区福利| 国产在线精品自拍| 精品人伦一区二区三区蜜桃免费| 国产精品视频公开费视频| 欧美国产第一页| 欧美韩国理论所午夜片917电影| 午夜免费久久久久| 精品视频中文字幕| 日本欧美中文字幕| 91免费看国产| 国产精品久久精品| 欧美在线国产精品| 一本色道久久88综合日韩精品| 国产在线精品一区免费香蕉| 日韩久久精品电影| 国产精品久久久久久av下载红粉| 日韩中文字幕在线免费观看| 欧美日韩免费在线观看| 国产在线精品一区免费香蕉| 亚洲天堂网站在线观看视频| 91精品久久久久久综合乱菊| 国产福利精品在线| 久久天天躁日日躁| 国产精品入口夜色视频大尺度| 国产亚洲一区二区在线| 欧美电影《睫毛膏》| 91久久国产精品| 国产在线视频91| 亚洲欧美国产高清va在线播| 久久av红桃一区二区小说| 亚洲成年人影院在线| 亚洲在线观看视频| 亚洲黄页视频免费观看| 中文字幕av一区中文字幕天堂| 免费不卡在线观看av| 精品久久久久久久久久ntr影视| 久久久久久一区二区三区| 亚洲成av人影院在线观看| 日韩高清电影免费观看完整| 欧美一区二三区| 久久久之久亚州精品露出| 国产精品亚洲аv天堂网| 欧美日韩第一视频| 日本久久久久久久久久久| 久久久99免费视频| 色哟哟亚洲精品一区二区| 欧美激情综合色综合啪啪五月| 精品香蕉在线观看视频一| 国内精品一区二区三区四区| 亚洲人成五月天| 成人做爰www免费看视频网站| 亚洲美女自拍视频| 欧美大尺度电影在线观看| 欧美激情国内偷拍| 日韩免费在线视频| 国产精品爱久久久久久久| 在线精品视频视频中文字幕| 欧美激情精品久久久| 中文字幕在线看视频国产欧美在线看完整| 亚洲精品国产电影| 一区二区三区美女xx视频| 久久国产精品首页| 51ⅴ精品国产91久久久久久| 久久成人国产精品| 欧美多人爱爱视频网站| 精品国产精品三级精品av网址| 亚洲福利视频免费观看| 黄色一区二区在线| 全球成人中文在线| 97在线日本国产| 久久久国产在线视频| 国产精品久久久久久久久久东京| 亚洲精品日韩丝袜精品| 欧美激情一区二区三级高清视频| 日韩欧美在线看| 亚洲国产精品福利| 久久久久久久久久av| 久久成人精品电影| 日韩av免费在线看| 国产在线精品一区免费香蕉| 国产免费亚洲高清| 欧美性xxxxxxxxx| 亚洲成人1234| 欧美亚洲第一区| 亚洲国产精品网站| 国产精品久久久久久久一区探花| 国产成人综合亚洲| 欧美一区三区三区高中清蜜桃| 欧美日韩一区二区在线播放| 亚洲美女视频网| 2023亚洲男人天堂| 中文字幕av一区中文字幕天堂| 91精品视频在线| 日韩欧美中文在线| 亚洲综合精品伊人久久| 亚洲美腿欧美激情另类| 在线免费看av不卡| 日韩高清人体午夜| 欧洲亚洲女同hd| 欧美大人香蕉在线| 成人国产精品一区| 日韩中文视频免费在线观看| 国产精品99导航| 亚洲精品久久久久久下一站| 欧美高清视频免费观看| 久久免费在线观看| 日韩免费不卡av| 97超级碰碰碰| 亚洲sss综合天堂久久| 亚洲第一免费播放区| 亚洲欧美日韩中文在线制服| 日韩成人xxxx| 亚洲免费影视第一页| 国产成人啪精品视频免费网| 亚洲成人免费网站| 国产伦精品免费视频| 精品亚洲va在线va天堂资源站| 91在线直播亚洲| 国产性猛交xxxx免费看久久| 欧美成人免费全部| 久久中文久久字幕| 欧美激情视频在线| 精品国产乱码久久久久久天美| 成人激情春色网| 日韩欧美国产免费播放| 久久久精品999| 狠狠色香婷婷久久亚洲精品| 欧美日韩一二三四五区| 午夜精品久久久久久久男人的天堂| 欧美激情亚洲视频| 91精品国产91久久久久久最新| 亚洲综合自拍一区| 日韩亚洲成人av在线| 91高清视频免费观看| 欧美在线视频免费| 欧美午夜视频一区二区| 成人欧美在线观看| 九九九久久国产免费| 成人信息集中地欧美| 欧美成人h版在线观看| 国产成人自拍视频在线观看|