力扣--深度优先算法/回溯算法216.组合总和 Ⅲ

思路分析:

  1. 深度优先搜索 (DFS): 通过递归实现,尝试从数字 1 到 9 中选择可能的数字,构建和为 n,长度为 k 的组合。
  2. 递归函数 dfs
    • 接收参数:result 为最终结果集,path 为当前正在生成的组合,n 为目标和,k 为组合长度,startn 为当前选择的数字起始位置,nownum 为当前组合的和。
    • 遍历当前可能的数字,更新当前组合的和和将当前数字加入临时结果集。
    • 如果当前组合的和等于目标值 n,且临时结果集的大小等于目标长度 k,则将其加入最终结果集。
    • 否则,继续递归生成组合,注意起始数字更新为 i+1
    • 回溯过程中,撤销选择,继续尝试其他可能的组合。
  3. 主函数:
    • 创建空的结果集 result 和临时结果集 path
    • 调用深度优先搜索函数 dfs,从数字 1 开始生成组合。
    • 返回最终结果。
cpp 复制代码
class Solution {
    // 定义深度优先搜索函数,用于生成组合
    void dfs(vector<vector<int>>& result, vector<int>& path, int n, int k, int startn, int nownum) {
        // 遍历当前可能的数字
        for (int i = startn; i <= 9; i++) {
            // 如果当前数字加上当前和已有和超过目标值 n,则跳出循环,因为后续数字只会更大
            if (nownum + i > n)
                break;

            // 更新当前和和将当前数字加入临时结果集
            nownum += i;
            path.push_back(i);

            // 如果当前和等于目标值 n,并且临时结果集的大小等于目标长度 k,则将结果加入最终结果集
            if (nownum == n && path.size() == k)
                result.push_back(path);
            else {
                // 继续递归生成组合,注意起始数字更新为 i+1
                dfs(result, path, n, k, i + 1, nownum);
            }

            // 回溯,撤销选择,继续尝试其他可能的组合
            nownum -= i;
            path.pop_back();
        }
        return;
    }

public:
    vector<vector<int>> combinationSum3(int k, int n) {
        // 存储最终结果的二维数组
        vector<vector<int>> result;
        
        // 存储当前正在生成的组合的临时结果
        vector<int> path;

        // 调用深度优先搜索函数,从数字 1 开始生成组合
        dfs(result, path, n, k, 1, 0);

        // 返回最终结果
        return result;
    }
};
相关推荐
梦境虽美,却不长1 分钟前
数据结构 线性表 学习 2025/6/12 21点27分
数据结构·学习
孟大本事要学习42 分钟前
算法第15天:继续二叉树|前序递归+回溯与前序递归的场景总结、最大二叉树、合并二叉树、二叉搜索树中的搜索、验证二叉搜索树
算法
GalaxyPokemon1 小时前
LeetCode - 76. 最小覆盖子串
运维·服务器·数据结构·算法·leetcode
嵌入式@秋刀鱼1 小时前
《 第三章-招式初成》 C++修炼生涯笔记(基础篇)程序流程结构
linux·开发语言·数据结构·c++·笔记·visual studio code
HaiQinyanAN1 小时前
【学习笔记】重载和重写的注意事项
c++·笔记·学习
手握风云-1 小时前
动态规划算法的欢乐密码(二):路径问题
算法·动态规划
小马爱打代码1 小时前
数据结构 - Java 队列
java·数据结构
梦境虽美,却不长1 小时前
C语言 学习 文件操作(开关,读写,定位,大小)操作 2025年6月8日12:19:24
c语言·开发语言·学习
西北大程序猿2 小时前
服务器代码知识点补充
服务器·开发语言·网络·c++·网络协议
Raven100862 小时前
L1G2-OpenCompass 评测书生大模型实践
算法