這篇文章將為大家詳細講解有關(guān)LeetCode如何解決組合總和問題,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)公司是專業(yè)的東平網(wǎng)站建設(shè)公司,東平接單;提供網(wǎng)站制作、成都網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行東平網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!
給定一個無重復(fù)元素的數(shù)組 candidates 和一個目標(biāo)數(shù) target ,找出 candidates 中所有可以使數(shù)字和為 target 的組合。
candidates 中的數(shù)字可以無限制重復(fù)被選取。
所有數(shù)字(包括 target)都是正整數(shù)。 解集不能包含重復(fù)的組合。
輸入:candidates = [2,3,6,7], target = 7, 所求解集為: [ [7], [2,2,3] ]
輸入:candidates = [2,3,5], target = 8, 所求解集為: [ [2,2,2,2], [2,3,3], [3,5] ]
1 <= candidates.length <= 30 1 <= candidates[i] <= 200 candidate 中的每個元素都是獨一無二的。 1 <= target <= 500
輸入: candidates = [2, 3, 6, 7],target = 7。
候選數(shù)組里有 2,如果找到了組合總和為 7 - 2 = 5 的所有組合,再在之前加上 2 ,就是 7 的所有組合;
同理考慮 3,如果找到了組合總和為 7 - 3 = 4 的所有組合,再在之前加上 3 ,就是 7 的所有組合,依次這樣找下去。
class Solution { public List> combinationSum(int[] candidates, int target) { int len = candidates.length; List
> res = new ArrayList<>(); if(len == 0){ return res; } Deque
path = new ArrayDeque<>(); dfs(candidates,0,len,target,path,res); return res; } public void dfs(int[] candidates,int begin,int len,int target,Deque path,List > res){ if(target < 0){ return; } if(target == 0){ res.add(new ArrayList<>(path)); } for(int i = begin; i < len; i++){ path.addLast(candidates[i]); dfs(candidates,i,len,target-candidates[i],path,res); path.removeLast(); } } }
關(guān)于“LeetCode如何解決組合總和問題”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。