news 2026/6/9 23:15:45

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进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 17:20:14

12、非 .NET 语言下信息卡依赖方的实现资源

非 .NET 语言下信息卡依赖方的实现资源 信息卡技术并非局限于微软技术栈,它具有跨平台和跨供应商的特性。本文将介绍在 PHP、Java、Ruby 和 Perl 等开发平台中实现信息卡依赖方(Relying Party)的相关资源,涵盖具体代码示例和其他可用的依赖方项目。 信息卡交换流程 在深…

作者头像 李华
网站建设 2026/6/9 3:08:06

突破存储瓶颈:macOS存储扩展终极解决方案

突破存储瓶颈&#xff1a;macOS存储扩展终极解决方案 【免费下载链接】iSCSIInitiator iSCSI Initiator for macOS 项目地址: https://gitcode.com/gh_mirrors/is/iSCSIInitiator 还在为Mac电脑存储空间不足而烦恼吗&#xff1f;&#x1f914; 当你面对"磁盘空间不…

作者头像 李华
网站建设 2026/6/9 18:36:50

低成本开源双臂机器人控制系统技术解析

低成本开源双臂机器人控制系统技术解析 【免费下载链接】aloha 项目地址: https://gitcode.com/gh_mirrors/al/aloha 技术架构原理 ALOHA系统采用主从式控制架构&#xff0c;通过映射算法实现操作者与执行机器人的精确同步。在系统核心配置中&#xff0c;定义了六个关…

作者头像 李华
网站建设 2026/6/7 22:16:08

遇到网站500内部服务器错误如何处理?如何预防这样的问题发生?

500内部服务器错误是网站运行中常见的问题之一&#xff0c;它通常意味着服务器无法完成请求&#xff0c;导致用户无法正常访问网站。这种错误可能由多种因素引起&#xff0c;包括代码问题、服务器配置错误、权限设置错误等。下面将详细介绍如何处理500错误以及如何预防500错误的…

作者头像 李华
网站建设 2026/6/9 0:13:18

Zotero格式修复实战完整指南:从混乱到规范的专家级解决方案

Zotero格式修复实战完整指南&#xff1a;从混乱到规范的专家级解决方案 【免费下载链接】zotero-format-metadata Linter for Zotero. An addon for Zotero to format item metadata. Shortcut to set title rich text; set journal abbreviations, university places, and ite…

作者头像 李华
网站建设 2026/6/9 19:55:05

Nexe完整指南:将Node.js应用打包成单文件可执行程序

Nexe完整指南&#xff1a;将Node.js应用打包成单文件可执行程序 【免费下载链接】nexe &#x1f389; create a single executable out of your node.js apps 项目地址: https://gitcode.com/gh_mirrors/ne/nexe 在Node.js应用部署过程中&#xff0c;开发者常常面临依赖…

作者头像 李华