news 2025/12/26 12:01:29

LeetCode 面试经典 150_回溯_组合(99_77_C++_中等)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 面试经典 150_回溯_组合(99_77_C++_中等)

LeetCode 面试经典 150_回溯_组合(99_77_C++_中等)

    • 题目描述:
    • 输入输出样例:
    • 题解:
      • 解题思路:
        • 思路一(回溯):
      • 代码实现
        • 代码实现(思路一(回溯)):

题目描述:

给定两个整数 n 和 k,返回范围 [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、组合问题可以想到回溯。
通过 示例1 中我们发现(仅看前一个位置时):
1 的组合有 [1,2],[1,3],[1,4]
2 的组合有 [2,3],[2,4]
3 的组合有 [3,4]
总结出一个规律,若 n 为前一个位置,后一个位置必定为 [n+1,n+2,…]

递归出口:组合个数 path.size()==k
递归体:组合问题需控制开始位置(start),防止重复(也就是总结出的规律),进入函数之前path.push_back(i);退出函数之后path.pop_back();

2、复杂度分析:
① 时间复杂度:O(C(n,k)⋅k),从n个元素中选择k个元素的组合数。
② 空间复杂度:O(C(n,k)⋅k),递归调用栈的空间O(k)(path)

代码实现

代码实现(思路一(回溯)):
classSolution{private:vector<vector<int>>ans;// 用于存储所有的组合结果vector<int>path;// 当前组合的路径// 回溯函数,生成从1到n中选择k个数字的组合voidbacktracking(intn,intk,intstart){// 如果当前组合的大小等于k,说明已找到一个组合if(path.size()==k){ans.push_back(path);// 将当前组合存入结果集return;// 返回,继续寻找其他组合}// 从start到n进行迭代,尝试添加数字到当前组合中for(inti=start;i<=n;i++){path.push_back(i);// 将当前数字添加到组合backtracking(n,k,i+1);// 递归调用,继续选择下一个数字path.pop_back();// 撤销选择,回溯}}public:// 主函数,初始化回溯过程并返回结果vector<vector<int>>combine(intn,intk){backtracking(n,k,1);// 从1开始进行组合生成returnans;// 返回所有组合结果}};

LeetCode 面试经典 150_回溯_组合(99_77)原题链接
欢迎大家和我沟通交流(✿◠‿◠)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/18 17:16:12

OpenModScan:工业自动化调试的免费Modbus神器

OpenModScan&#xff1a;工业自动化调试的免费Modbus神器 【免费下载链接】OpenModScan Open ModScan is a Free Modbus Master (Client) Utility 项目地址: https://gitcode.com/gh_mirrors/op/OpenModScan 在工业自动化和物联网设备开发领域&#xff0c;Modbus通讯协议…

作者头像 李华
网站建设 2025/12/18 17:15:30

Node.js应用打包终极指南:一键生成独立可执行文件的完整教程

Node.js应用打包终极指南&#xff1a;一键生成独立可执行文件的完整教程 【免费下载链接】nexe &#x1f389; create a single executable out of your node.js apps 项目地址: https://gitcode.com/gh_mirrors/ne/nexe 还在为Node.js应用部署繁琐而烦恼吗&#xff1f;…

作者头像 李华
网站建设 2025/12/20 4:19:56

13、个性化体验:提升用户价值与商业机会的关键

个性化体验:提升用户价值与商业机会的关键 1. 个性化体验的重要性 个性化体验在商业领域中扮演着至关重要的角色,它不仅能提升用户的满意度和忠诚度,还能为企业带来更高的销售额和更多的客户推荐。下面通过几个实际场景来深入了解个性化体验的魅力。 1.1 零售行业的个性化…

作者头像 李华
网站建设 2025/12/18 17:15:10

香港 澳门商场春节美陈策划设计公司优选,节日活动靠谱机构

新春佳节渐近&#xff0c;港澳地区的商场里&#xff0c;浓浓的年味正悄然积蓄。当传统节日的喜庆氛围与现代商业空间巧妙碰撞&#xff0c;一场兼具文化内涵与视觉震撼的场景打造&#xff0c;既能为商场增添蓬勃生机&#xff0c;又能深深触动本地居民的情感纽带&#xff0c;勾起…

作者头像 李华
网站建设 2025/12/18 17:14:36

Kotaemon如何应对知识过时问题?版本管理机制介绍

Kotaemon如何应对知识过时问题&#xff1f;版本管理机制介绍 在金融、医疗、法律等对信息准确性要求极高的领域&#xff0c;一个智能问答系统若回答“去年的合规政策”&#xff0c;而实际规则早已更新——这不仅是体验问题&#xff0c;更可能引发严重的业务风险。随着大语言模型…

作者头像 李华