力扣--深度优先算法/回溯算法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;
    }
};
相关推荐
AA陈超4 分钟前
虚幻引擎UE5专用服务器游戏开发-20 添加基础能力类与连招能力
c++·游戏·ue5·游戏引擎·虚幻
阿捏利23 分钟前
C Primer Plus 第6版 编程练习——第7章(上)
c语言·编程题·c primer plus
mit6.82425 分钟前
[Meetily后端框架] AI摘要结构化 | `SummaryResponse`模型 | Pydantic库 | vs marshmallow库
c++·人工智能·后端
R-G-B32 分钟前
【02】MFC入门到精通——MFC 手动添加创建新的对话框模板
c++·mfc·mfc 手动添加创建新的对话框
是白可可呀34 分钟前
LeetCode 169. 多数元素
leetcode
linux kernel1 小时前
第七讲:C++中的string类
开发语言·c++
jz_ddk1 小时前
[实战]调频(FM)和调幅(AM)信号生成(完整C语言实现)
c语言·算法·信号处理
Tipriest_1 小时前
[数据结构与算法] 优先队列 | 最小堆 C++
c++·优先队列·数据结构与算法·最小堆
CloudAce云一1 小时前
谷歌云代理商:谷歌云TPU/GPU如何加速您的AI模型训练和推理
算法
宛西南浪漫戈命1 小时前
Centos 7下使用C++使用Rdkafka库实现生产者消费者
c++·centos·linq