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


    题目链接

    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;
        }
    }
    
  • 相关阅读:
    用面向对象做练习题
    面向对象
    php数组
    PHP函数
    php语句函数
    mySQL函数
    mySQL相关知识
    mySQL建表及练习题(下)
    mySQL建表及练习题(上)
    HTML5 canvas画布标签
  • 原文地址:https://www.cnblogs.com/XDU-Lakers/p/13654801.html
Copyright © 2020-2023  润新知