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

LeetCode 热题 100_组合总和(58_39_中等_C++)(递归(回溯))

LeetCode 热题 100_组合总和(58_39)

    • 题目描述:
    • 输入输出样例:
    • 题解:
      • 解题思路:
        • 思路一(递归(回溯)):
      • 代码实现
        • 代码实现(思路一(递归(回溯))):
        • 以思路一为例进行调试

题目描述:

给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target ,找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 ,并以列表形式返回。你可以按 任意顺序 返回这些组合。

candidates 中的 同一个 数字可以 无限制重复被选取 。如果至少一个数字的被选数量不同,则两种组合是不同的。

对于给定的输入,保证和为 target 的不同组合数少于 150 个。

输入输出样例:

示例 1:
输入:candidates = [2,3,6,7], target = 7
输出:[[2,2,3],[7]]
解释
2 和 3 可以形成一组候选,2 + 2 + 3 = 7 。注意 2 可以使用多次。
7 也是一个候选, 7 = 7 。
仅有这两种组合。

示例 2:
输入: candidates = [2,3,5], target = 8
输出: [[2,2,2,2],[2,3,3],[3,5]]

示例 3:
输入: candidates = [2], target = 1
输出: []

提示:
1 <= candidates.length <= 30
2 <= candidates[i] <= 40
candidates 的所有元素 互不相同
1 <= target <= 40

题解:

解题思路:

思路一(递归(回溯)):

1、使用回溯的方法解组合问题时,最好的方法是画出递归树进行分析。
在这里插入图片描述
通过递归树不难分析出:
     ①、递归出口:sum==target(记录答案+回溯) 或者 sum>target(回溯)
我们可以记录path中的总和为sum,通过sum与target的比较来判断。也可以使用target-path数组中的元素与0进行比较来判断,其效果相同。
     ②、递归体:sum < target(查找可能的组合)

2、复杂度分析:
① 时间复杂度:O(S),其中 S 为所有可行解的长度之和(也就是递归树的节点数)。
② 空间复杂度:O(target)。除答案数组外,空间复杂度取决于递归的栈深度(也就是上图递归树的深度),在最差情况下需要递归 O(target) 层。

代码实现

代码实现(思路一(递归(回溯))):
class Solution {
private://记录其中一个组合vector<int> path;//记录所有满足组合总和的组合vector<vector<int>> ans;//递归(回溯)计算组合总和void backtracking(vector<int>& candidates, int target,int startIndex){//为目标数 “target” 的一个组合,存储到ans中if (target==0){     ans.emplace_back(path);return;}//当path中的数据大于“target”返回(path无需再添加元素,需减少元素)if (target<0) return;//注意这里i的开始位置,是为了避免出现“全排列”类型的重复for (int i = startIndex; i < candidates.size(); i++){path.emplace_back(candidates[i]);//继续添加其他元素,注意一个元素可以重复添加所以startIndex=ibacktracking(candidates,target - candidates[i],i);//回溯(和path.emplace_back(candidates[i])对应)path.pop_back();}}public:vector<vector<int>> combinationSum(vector<int>& candidates, int target) {//清空ans和path中的数据,防止上次调用存在数据残留ans.clear();path.clear();//递归(回溯)计算组合总和backtracking(candidates,target,0);return ans;}
};
以思路一为例进行调试
#include<iostream>
#include <vector>
using namespace std;class Solution {
private://记录其中一个组合vector<int> path;//记录所有满足组合总和的组合vector<vector<int>> ans;//递归(回溯)计算组合总和void backtracking(vector<int>& candidates, int target,int startIndex){//为目标数 “target” 的一个组合,存储到ans中if (target==0){     ans.emplace_back(path);return;}//当path中的数据大于“target”返回(path无需再添加元素,需减少元素)if (target<0) return;//注意这里i的开始位置,是为了避免出现“全排列”类型的重复for (int i = startIndex; i < candidates.size(); i++){path.emplace_back(candidates[i]);//继续添加其他元素,注意一个元素可以重复添加所以startIndex=ibacktracking(candidates,target - candidates[i],i);//回溯(和path.emplace_back(candidates[i])对应)path.pop_back();}}public:vector<vector<int>> combinationSum(vector<int>& candidates, int target) {//清空ans和path中的数据,防止上次调用存在数据残留ans.clear();path.clear();//递归(回溯)计算组合总和backtracking(candidates,target,0);return ans;}
};int main(int argc, char const *argv[])
{vector<int> candidates={2,3,5};int target=8;//计算组合总和Solution s;vector<vector<int>> ans=s.combinationSum(candidates,target);//输出计算的组合总和for (int i = 0; i < ans.size(); i++){cout<<"[";for (int j = 0; j < ans[i].size(); j++){cout<<ans[i][j];if (j!=ans[i].size()-1){cout<<" ";}}cout<<"]";}return 0;
}

LeetCode 热题 100_组合总和(58_39)原题链接
欢迎大家和我沟通交流(✿◠‿◠)

http://www.lryc.cn/news/537013.html

相关文章:

  • 使用PHP爬虫获取1688商品分类:实战案例指南
  • Nginx location 和 proxy_pass 配置详解
  • 云创智城充电系统:基于 SpringCloud 的高可用、可扩展架构详解-多租户、多协议兼容、分账与互联互通功能实现
  • AIP-143 标准代号
  • 机器视觉--数字图像格式
  • Kotlin 2.1.0 入门教程(十七)接口
  • 渗透测试工具:SQLmap安装教程及使用
  • 4.SpringSecurity在分布式环境下的使用
  • RocketMQ和Kafka如何实现顺序写入和顺序消费?
  • SQL联合查询
  • deepseek:三个月备考高级系统架构师
  • 支持向量机原理
  • DeepSeek人工智能AI汽车营销销售培训讲师培训师唐兴通讲课汽车销售大数据存量客户数字化营销数字化销售大模型销售话术引流内容社群私域
  • Molecular Communication(分子通信)与 Molecular Semantic Communication(分子语义通信)
  • Webpack代码分割、分割策略性能优化详解
  • 大脑网络与智力:基于图神经网络的静息态fMRI数据分析方法|文献速递-医学影像人工智能进展
  • ArcGIS Pro显示缓存空间不足导致编辑或加载数据显示不完全
  • 天童美语:观察你的生活
  • 网络通信的基石:深入理解 TCP/IP 协议栈与 TCP/UDP 协议
  • 数据结构-栈和队列的应用
  • SpringBoot Bug 日志
  • halo发布文章的插件问题分析
  • 2.5 模块化迁移策略:从传统项目到模块化系统
  • java商城解决方案
  • 算法-哈希表篇05-四数相加II
  • WPS或word接入智能AI
  • Leetcode:学习记录
  • 86.在 Vue 3 中使用 OpenLayers 自定义组件(放大、缩小、长度测量、面积测量)
  • http 与 https 的区别?
  • SAIL-RK3576单板运行7b的deepseek对话模型