Combinations -- 回溯法--力扣101算法题解笔记

6.3Combinations -- 回溯法

题目描述

给定一个整数n和另一个整数k,在1到n中选取k个数组的所有组合方法

输入输出样例

Input : n = 4 , k = 2

Output: \[1 , 2, 1 , 3, 1 , 4, 2 , 3, 2 , 4, 3 , 4 ]

输出的二维数组可以以任意顺序输出

题解

发现了不,基本上所有找组合、排列问题,都用回溯法是较为方便的。

排列回溯是交换位置然后记录,回溯,接着交换。

组合回溯是 是否把当前数字加入到结果中。

cpp 复制代码
#include <vector>
#include <iostream>
using namespace std;

void backtracking(vector<vector<int>>& ans, vector<int>& comb,
    int& count, int pos, int n, int k) {
    if (count == k) {
        ans.push_back(comb);
        return;
    }
    for (int i = pos; i <= n; ++i) {
        comb[count++] = i;  //修改当前节点
        backtracking(ans, comb, count, i + 1, n, k);    //递归子节点
        --count;    //回改当前节点状态
    }
}

vector<vector<int>> combine(int n , int k) {
    vector<vector<int>> ans;
    vector<int> comb(k, 0);
    int count = 0;
    backtracking(ans, comb, count, 1, n, k);
    return ans;
}

int main() {
    int n = 4, k = 2;
    vector<vector<int>> res = combine(n, k);

    cout << "[";
    for (int i = 0; i < res.size(); ++i) {
        if (i > 0) cout << ", ";
        cout << "[" << res[i][0] << ", " 
                    << res[i][1] << "]";
    }
    cout << "]" << endl;

    return 0;
}
相关推荐
千纸鹤安安3 小时前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者5 小时前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
北域码匠9 小时前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
kisshyshy12 小时前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC1 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635071 天前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC1 天前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥1 天前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程