代码随想录 回溯—组合

递归函数三部曲:

递归函数参数返回值

确定终止条件

单层递归逻辑

**思路:**result存组合结果,path存一个结果生成的路径,回溯函数的参数除了所传进去的n和k,还要传进一个起始点startIndex,这就是确定了参数返回值;if()确定终止条件;for循环里先把当前节点push进path,再进行递归,最后pop出来,给后面的节点pop进留位子。最后返回result。

c++题解:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> result;
    vector<int> path;
    void backtrace(int n,int k,int startIndex)
    {
        if(path.size()==k)
            result.push_back(path);
        for(int i=startIndex;i<=n;i++)
        {
            path.push_back(i);
            backtrace(n,k,i+1);//递归
            path.pop_back();
        }
        return;
    }

    vector<vector<int>> combine(int n, int k) {
        backtrace(n,k,1);
        return result;
    }
};
相关推荐
weixin_461769407 分钟前
3. 无重复字符的最长子串
c++·算法·滑动窗口·最长字串
Morwit9 分钟前
【力扣hot100】 312. 戳气球(区间dp)
c++·算法·leetcode
CoovallyAIHub19 分钟前
摄像头如何“看懂”你的手势?手势识别实现新人机交互
深度学习·算法·计算机视觉
Q741_14731 分钟前
C++ 栈 模拟 力扣 394. 字符串解码 每日一题 题解
c++·算法·leetcode·模拟·
AI科技星38 分钟前
张祥前统一场论:空间位移条数概念深度解析
数据结构·人工智能·经验分享·算法·计算机视觉
Wuliwuliii42 分钟前
闵可夫斯基和、需存储的最小状态集
c++·算法·动态规划·闵可夫斯基和
CoovallyAIHub1 小时前
颠覆认知!遥感船舶检测“越深越好”是误区?LiM-YOLO证明“少即是多”
深度学习·算法·计算机视觉
byzh_rc1 小时前
[算法设计与分析-从入门到入土] 贪心算法
算法·动态规划
Felven1 小时前
C. Contrast Value
c语言·开发语言·算法
natide1 小时前
表示/嵌入差异-1-欧几里得距离(Euclidean Distance)-L2 距离(L2 distance)-欧式距离的标准化
人工智能·pytorch·python·深度学习·算法·自然语言处理