您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關LeetCode如何解決組合總和問題,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
給定一個無重復元素的數組 candidates 和一個目標數 target ,找出 candidates 中所有可以使數字和為 target 的組合。
candidates 中的數字可以無限制重復被選取。
所有數字(包括 target)都是正整數。 解集不能包含重復的組合。
輸入: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。
候選數組里有 2,如果找到了組合總和為 7 - 2 = 5 的所有組合,再在之前加上 2 ,就是 7 的所有組合;
同理考慮 3,如果找到了組合總和為 7 - 3 = 4 的所有組合,再在之前加上 3 ,就是 7 的所有組合,依次這樣找下去。
class Solution { public List<List<Integer>> combinationSum(int[] candidates, int target) { int len = candidates.length; List<List<Integer>> res = new ArrayList<>(); if(len == 0){ return res; } Deque<Integer> path = new ArrayDeque<>(); dfs(candidates,0,len,target,path,res); return res; } public void dfs(int[] candidates,int begin,int len,int target,Deque<Integer> path,List<List<Integer>> 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(); } } }
關于“LeetCode如何解決組合總和問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。