当前位置: 首页 > news >正文

day155—回溯—组合(LeetCode-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 到 n 的数字中选取 k 个数字的所有组合(组合不考虑顺序,比如 n=4、k=2 时,输出[[4,3],[4,2],[4,1],[3,2],[3,1],[2,1]]),采用「回溯 + 剪枝」的思路实现,是组合问题的经典高效解法。

核心逻辑

  1. 成员变量作用

    • path:临时数组,存储当前正在构造的组合(比如选取了 2 个数字时,path 可能是 [4,3]);
    • ans:最终结果数组,存储所有符合条件的 k 个数组合。
  2. 递归函数dfs逻辑

    • 参数n:当前可选数字的上界(只能从1~n中选数);k:需要选取的数字个数;
    • 剪枝条件(提前终止无效递归):if(n < k - len)—— 剩余可选数字个数(n)小于 “还需要选的数字个数(k-len)”,说明不可能凑够 k 个数,直接返回,避免无效递归;
    • 终止条件:if(len == k)—— 当前组合的长度等于 k,说明已选够 k 个数,将path加入ans后返回;
    • 核心流程(从大到小枚举 + 回溯):① 遍历从n1的所有数字i(从大到小选,避免重复组合,比如不会同时出现 [3,4] 和 [4,3]);② 选数字i:将i加入path,递归调用dfs(i-1, k)(下一轮只能从1~i-1中选数,保证组合内数字递减,无重复);③ 回溯:递归返回后,执行path.pop_back()删掉刚加入的数字,尝试下一个可选数字。
  3. 主函数combine

    • 从数字上界n开始调用dfs,启动组合构造过程;
    • 最终返回存储所有 k 数组合的ans

关键特点

  • 剪枝优化:n < k - len的判断是核心优化点,能大幅减少递归次数(比如 n=5、k=3,当前 path 长度为 1,还需选 2 个数,若剩余可选数字只有 1 个,直接终止);
  • 去重逻辑:从大到小枚举数字,且下一轮只能选更小的数字,天然保证组合内数字递减,避免生成重复组合(组合不考虑顺序,此逻辑符合组合的定义)。

总结

  1. 核心思路:递归枚举可选数字,从大到小选数避免重复组合,通过剪枝提前终止无效递归,回溯遍历所有合法的 k 数组合;
  2. 关键操作:path.push_back()(选数)和path.pop_back()(回溯)是遍历所有组合的核心,剪枝条件是提升效率的关键;
  3. 功能效果:能输出 1~n 中选 k 个数的所有组合,无重复、无遗漏,且效率高于无剪枝的暴力枚举。

以 n=4、k=2 为例,最终会生成所有 2 数组合:[[4,3],[4,2],[4,1],[3,2],[3,1],[2,1]],符合组合的定义(不考虑顺序)。

函数源码:

class Solution { public: vector<int>path={}; vector<vector<int>>ans={}; void dfs(int n,int k){ int len=path.size(); if(n<k-len){ return; } if(len==k){ ans.push_back(path); return; } for(int i=n;i>0;i--){ path.push_back(i); dfs(i-1,k); path.pop_back(); } } vector<vector<int>> combine(int n, int k) { dfs(n,k); return ans; } };
http://www.jsqmd.com/news/269753/

相关文章:

  • 实用指南:零基础学AI大模型之MultiQueryRetriever多查询检索全解析
  • 基于Hough变换的答题卡识别MATLAB之旅
  • 计算机小程序毕设实战-基于django+微信小程序的运动饮食健康生活系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • Day23-20260119
  • C# 实现 TCP/IP 客户端与服务器数据交互及与西门子 S7 - 200Smart 通讯
  • 2026大专计算机专业学数据分析的价值分析
  • PySide系列-07-QMainWindow
  • 【计算机毕业设计案例】基于微信小程序的考研资源共享平台的设计与实现基于django+微信小程序的考研信息查询系统(程序+文档+讲解+定制)
  • c++中的常用栈操作
  • 2026/1/17-Atcoder Beginner Contest 441 T1~4
  • 群友靶机lara复现 - 场
  • 小程序毕设选题推荐:基于django+微信小程序的健康生活系统个人健康生活平台小程序【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 信件分析(2)
  • 探索人脸识别追踪:从图像采集到电机驱动的奇妙旅程
  • ​​​​​​​推荐10个数据备份与恢复工具?先搞懂这3种备份方式,再选才不踩坑!
  • 手把手教你降AI不伤文:保姆级操作让论文既通过检测又保持专业
  • FPGA 实现多路高精度 AD1246 高速数据采集与接收设计
  • ACPI!gReadyQueue中的plistCtxtQ和ACPI!GetOpRegionScopeWorker函数中的赋值*state->PciObj = state->Parent
  • 2026年8款免费降AI率工具实测推荐,毕业党必看
  • 微分方程一维抛物热传导方程数值解法全解析
  • 《实时渲染》第2章-图形渲染管线-2.2应用程序阶段
  • 深度解析2026论文优化方案:从DeepSeek到学术猹,谁是NLP降重的最优解? - 品牌观察员小捷
  • Comsol 中浆液扩散模型:注浆过程的数字化洞察
  • 2026降AI工具红黑榜:实测8款后我只推荐这3个
  • 打造学生信息管理系统:从构思到实现
  • 2026中专生考大数据与财务管理专业学习指南
  • 知网AIGC检测不通过?2026最新降AI攻略来了
  • 小程序毕设项目推荐-基于django+微信小程序的考研信息查询系统考研院校推荐系统 考研分数线发布查询【附源码+文档,调试定制服务】
  • ArcGIS大师之路500技---062调整面要素到指定面积
  • 知网AIGC检测不通过?学长亲测的避坑指南