news 2026/6/12 21:31:57

day155—回溯—组合(LeetCode-77)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 17:04:17

告别嘈杂!Moodist%20白噪音神器,搭配%20cpolar%20解锁随时随地的宁静

Moodist 作为一款沉浸式环境音效生成器&#xff0c;核心功能是将雨打屋檐、篝火噼啪、山间溪流等数十种自然与生活音效拆分为独立模块&#xff0c;用户可自由调配比例&#xff0c;打造专属治愈音效&#xff0c;适配职场人、学生党、宝妈等各类需要舒缓环境的人群&#xff0c;其…

作者头像 李华
网站建设 2026/6/12 13:04:49

电动汽车与燃油车仿真模型大揭秘

纯电动汽车BEV 电机 电池 VCU控制仿真模型纯电动汽车整车仿真测试; 附赠传统燃油车 仿真模型 发动机 传动系 车辆模型 . 模型均有直观的模型搭建说明描述&#xff01;嘿&#xff0c;各位技术宅们&#xff01;今天咱来唠唠超酷的纯电动汽车&#xff08;BEV&#xff09;和传统燃…

作者头像 李华
网站建设 2026/6/12 13:53:09

科技设备免费处理的秘密技巧:快速回收打印机和笔记本电脑

我们都有那样一个"墓地"衣柜&#xff0c;里面塞满了旧笔记本电脑和缠成一团的打印机电缆&#xff0c;因为没人愿意处理正确丢弃它们的麻烦事。但到了2026年&#xff0c;让电脑和其他科技设备烂在那里不仅浪费空间&#xff0c;更错失了为地球做最基本贡献而不花一分钱…

作者头像 李华
网站建设 2026/5/25 8:34:23

研究人员通过数据投毒技术保护知识图谱免遭盗用

来自中国和新加坡高校的研究人员开发了一项新技术&#xff0c;能够使被盗的知识图谱数据在未经授权的情况下被整合到GraphRAG AI系统中时变得无用。大语言模型基于训练数据进行预测&#xff0c;无法有效回应其他数据的查询。AI行业通过检索增强生成&#xff08;RAG&#xff09;…

作者头像 李华
网站建设 2026/6/12 21:52:34

打造学生信息管理系统:从构思到实现

简单学生信息管理系统&#xff08;附源码&#xff09;&#xff0c;原生无边框winformsqlite&#xff0c;主要运用窗体继承动态导航菜单反射创建窗体对象家事件刷新数据&#xff0c;自定义4种类型弹窗类型对话框&#xff0c;数据分层&#xff0c;增删查改都实现了&#xff0c;其…

作者头像 李华
网站建设 2026/6/10 17:50:24

聊聊A*算法与Dijkstra算法的Matlab及C实现

A*算法matlab程序&#xff0c;附送c程序 Djikstra算法matlab程序 代码特点&#xff1a; 1. matlab读入excel制作的地图&#xff0c;障碍物为1&#xff1b; 2.设置起始点和终止点&#xff0c;A*算法会输出一条近最优路径&#xff0c;因为这是启发式算法&#xff1b; 3.Dijkstra算…

作者头像 李华