77. 组合

题目

给定两个整数 nk,返回范围 [1, n] 中所有可能的 k 个数的组合。

你可以按 任何顺序 返回答案。

示例 1:

复制代码
输入:n = 4, k = 2
输出:
[
  [2,4],
  [3,4],
  [2,3],
  [1,2],
  [1,3],
  [1,4],
]

示例 2:

复制代码
输入:n = 1, k = 1
输出:[[1]]

提示:

  • 1 <= n <= 20
  • 1 <= k <= n

思路

这道题按照我们正常的思路就是从一开始和1后面的其他数字组合,然后再从2开始和后面的数字组合...代码中我们也可以采用这样的思路,按顺序排列可以防止有遗漏或者重复。从起始数字从1开始,把他加入自己数组,接着递归处理后续数字生成更多组合;如果临时组合长度达到k,就把他作为一个有效组合保存到res;每次递归返回后,把最后添加的数字删除,尝试其他可能,直到遍历完所有可能的组合,最终就能得到所有组合。

代码

cpp 复制代码
class Solution {
public:
    vector<vector<int>> res;//结果数组
    vector<int> p;//子集数组
    void hs(int n,int k,int s)
    {
        if(p.size()==k)//子集数组中的数达到k个就有了一个结果
        {
            res.push_back(p);
            return;
        }
        for(int i=s;i<=n-(k-p.size())+1;i++)//n-(k-p.size())+1是当前位置所能选择的最大数字
        {
            p.push_back(i);//处理节点
            hs(n,k,i+1);//进入递归,继续生成子集
            p.pop_back();//删除p中最后添加的数字
        }
    }
    vector<vector<int>> combine(int n, int k) {
        hs(n,k,1);
        return res;
    }
};
相关推荐
Keep_Trying_Go21 分钟前
基于Zero-Shot的目标计数算法详解(Open-world Text-specified Object Counting)
人工智能·pytorch·python·算法·多模态·目标统计
xl.liu41 分钟前
零售行业仓库商品数据标记
算法·零售
confiself1 小时前
通义灵码分析ms-swift框架中CHORD算法实现
开发语言·算法·swift
做怪小疯子1 小时前
LeetCode 热题 100——二叉树——二叉树的层序遍历&将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
CoderYanger1 小时前
递归、搜索与回溯-记忆化搜索:38.最长递增子序列
java·算法·leetcode·1024程序员节
AA陈超2 小时前
Lyra学习004:GameFeatureData分析
c++·笔记·学习·ue5·虚幻引擎
xlq223222 小时前
22.多态(下)
开发语言·c++·算法
CoderYanger2 小时前
C.滑动窗口-越短越合法/求最长/最大——2958. 最多 K 个重复元素的最长子数组
java·数据结构·算法·leetcode·哈希算法·1024程序员节
不会c嘎嘎3 小时前
【数据结构】AVL树详解:从原理到C++实现
数据结构·c++
却话巴山夜雨时i3 小时前
394. 字符串解码【中等】
java·数据结构·算法·leetcode