首页 > 其他 > 详细

【LeetCode】216. 组合总和 III(回溯)

时间:2020-09-11 23:27:04      阅读:85      评论:0      收藏:0      [点我收藏+]

题目链接

216. 组合总和 III

题目描述

找出所有相加之和为 n 的 k 个数的组合。组合中只允许含有 1 - 9 的正整数,并且每种组合中不存在重复的数字。

示例 1:
输入: k = 3, n = 7
输出: [[1,2,4]]

示例 2:
输入: k = 3, n = 9
输出: [[1,2,6], [1,3,5], [2,3,4]]

说明:

所有数字都是正整数。
解集不能包含重复的组合。

解题思路

经典回溯

技术分享图片

有了上面回溯算法的整体框架,就非常容易写出整个代码啦,主要还是联想到递归树,递归结束条件顺序的判断!

AC代码

class Solution {

    List<List<Integer>> ans = new ArrayList<>();
    List<Integer> temp = new ArrayList<>();
    int[] vist = new int[10];

    void dfs(int start,int k,int n,int num){
        //必须先判断当个数等于k时候,tot值是否等于n,如果等于加入ans中,如果不等于则返回(回溯)
        int tot = 0;
        for(int i = 0; i < temp.size(); i++) tot += temp.get(i);
        if(tot == n && num == k){
            ans.add(new ArrayList<>(temp));
            return;
        }
        //要注意递归返回条件的先后顺序
        if(num == k) return;
        for(int i = start; i <= 9; i++){
            if(vist[i] == 0){
                vist[i] = 1;
                temp.add(i);
                num++;
                dfs(i+1,k,n,num);
                num--;
                temp.remove(temp.size() - 1);
                vist[i] = 0;
            }
        }
    }

    public List<List<Integer>> combinationSum3(int k, int n) {
        dfs(1,k,n,0);
        return ans;
    }
}

【LeetCode】216. 组合总和 III(回溯)

原文:https://www.cnblogs.com/XDU-Lakers/p/13654801.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!