C++回溯算法中組合的相關(guān)問題分析

回溯算法模板
void backtracking(參數(shù)) {
if (終止條件) {
存放結(jié)果;
return;
}
for (選擇:本層集合中元素(樹中節(jié)點孩子的數(shù)量就是集合的大?。? {
處理節(jié)點;
backtracking(路徑,選擇列表); // 遞歸
回溯,撤銷處理結(jié)果
}
}
回溯問題,最關(guān)鍵的是畫出二叉樹,遍歷、剪枝問題都要通過直觀的觀察才能總結(jié)
一、組合
剪枝策略
已經(jīng)選擇的元素個數(shù):path.size();
還需要的元素個數(shù)為: k - path.size();
在集合n中至多要從該起始位置 : n - (k - path.size()) + 1,開始遍歷
class Solution {
private:
vector<vector<int>> result;
vector<int> path;
void backtracking(int n,int k,int startIndex){
if(path.size()==k){
result.push_back(path);
return;
}
for(int i=startIndex;i<=n-(k-path.size())+1;i++){
path.push_back(i);
backtracking(n,k,i+1);
path.pop_back();
}
}
public:
vector<vector<int>> combine(int n, int k) {
backtracking(n,k,1);
return result;
}
};二、組合總和III與組合總和
1.組合總和III
在組合的基礎(chǔ)上,多了一個求和的操作,求和也可以剪枝
class Solution {
private:
vector<vector<int>> result;
vector<int> path;
void backtracking(int sum,int k,int n,int startIndex){
if(sum>n) return;
if(path.size()==k){
if(sum==n) result.push_back(path);
return;
}
for(int i=startIndex;i<=9-(k-path.size())+1;i++){
path.push_back(i);
sum+=i;
backtracking(sum,k,n,i+1);
sum-=i;
path.pop_back();
}
}
public:
vector<vector<int>> combinationSum3(int k, int n) {
backtracking(0,k,n,1);
return result;
}
};2.組合總和
本題與組合III的區(qū)別在于,不限制組合內(nèi)數(shù)字的個數(shù),且同一個數(shù)字可以無限制重復(fù)被選取,體現(xiàn)在代碼上就是,向下遞歸的時候,i不變
class Solution {
private:
vector<int> path;
vector<vector<int>> result;
void backtracking(vector<int>& candidates, int target,int index,int sum){
if(sum>target) return;
if(sum==target){
result.push_back(path);
return;
}
for(int i=index;i<candidates.size();i++){
path.push_back(candidates[i]);
sum+=candidates[i];
backtracking(candidates,target,i,sum);
sum-=candidates[i];
path.pop_back();
}
}
public:
vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
backtracking(candidates,target,0,0);
return result;
}
};3.組合總和II
本題和組合總和的區(qū)別在于,輸入樣例中含有重復(fù)元素時,輸出樣例不能有重復(fù)元素
同一條枝干上,元素可以相同;而不同的枝干則不能重復(fù)
即:橫向遍歷不能重復(fù)、縱向遍歷可以重復(fù)
class Solution {
private:
vector<int> path;
vector<vector<int>> result;
void backtracking(vector<int>& candidates, int target,int index,int sum){
if(sum>target) return;
if(sum==target){
result.push_back(path);
return;
}
for(int i=index;i<candidates.size();i++){
if(i>index&&candidates[i]==candidates[i-1])
continue;
path.push_back(candidates[i]);
sum+=candidates[i];
backtracking(candidates,target,i+1,sum);
sum-=candidates[i];
path.pop_back();
}
}
public:
vector<vector<int>> combinationSum2(vector<int>& candidates, int target) {
sort(candidates.begin(),candidates.end());
backtracking(candidates,target,0,0);
return result;
}
};三、電話號碼的字母組合
這題很好的考察了:for循環(huán)橫向遍歷、遞歸縱向遍歷的知識點
class Solution {
private:
const string letterMap[10]={
"",
"",
"abc",
"def",
"ghi",
"jkl",
"mno",
"pqrs",
"tuv",
"wxyz"
};
public:
string path;
vector<string> result;
void backtracking(string digits,int index){
if(index==digits.size()){
result.push_back(path);
return;
}
int digit=digits[index]-'0';
string letter=letterMap[digit];
for(int i=0;i<letter.size();i++){
path.push_back(letter[i]);
backtracking(digits,index+1);
path.pop_back();
}
}
vector<string> letterCombinations(string digits) {
if(digits.size()==0)
return result;
backtracking(digits,0);
return result;
}
};到此這篇關(guān)于C++回溯算法中組合的相關(guān)問題分析的文章就介紹到這了,更多相關(guān)C++回溯算法組合內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Visual?Studio2022配置ReSharper?C++?常用設(shè)置方法
這篇文章主要介紹了Visual?Studio2022配置ReSharper?C++?常用設(shè)置,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),文中介紹了卸載Resharper的方法及Resharper激活碼,感興趣的朋友參考下吧2024-01-01
QT布局管理詳解QVBoxLayout與QHBoxLayout及QGridLayout的使用
在這篇文章中,你將知道水平布局、垂直布局、網(wǎng)格布局如何輕松上手,以純代碼方式展示。對齊方式,大小設(shè)置,圖片頭像匹配標(biāo)簽,布局器里面的組件大小隨意切換大小,認(rèn)真看完這篇文章,QT布局管理器熟練使用2022-06-06
Visual C++中Tab View的多種實現(xiàn)方法
這篇文章主要介紹了Visual C++中Tab View的多種實現(xiàn)方法,包括了CTabCtrl控件、CSheetCtrl標(biāo)簽選擇窗口以及靜態(tài)分割窗口等實現(xiàn)Tab View的方法,需要的朋友可以參考下2014-10-10
C語言中數(shù)據(jù)是如何存儲在內(nèi)存中的
使用編程語言進(jìn)行編程時,需要用到各種變量來存儲各種信息。變量保留的是它所存儲的值的內(nèi)存位置。這意味著,當(dāng)您創(chuàng)建一個變量時,就會在內(nèi)存中保留一些空間。您可能需要存儲各種數(shù)據(jù)類型的信息,操作系統(tǒng)會根據(jù)變量的數(shù)據(jù)類型,來分配內(nèi)存和決定在保留內(nèi)存中存儲什么2022-04-04

