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=i
            backtracking(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=i
            backtracking(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)原题链接
欢迎大家和我沟通交流(✿◠‿◠)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/969704.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2024年12月电子学会青少年机器人技术等级考试(五级)理论综合真题

202412 青少年等级考试机器人理论真题五级 一、单选题 第 1 题 ESP32 for Arduino&#xff0c;下列选项中&#xff0c;具有根据电容量的变化&#xff0c;获取返回值的函数是&#xff1f;&#xff08; &#xff09; A&#xff1a;touchRead() B&#xff1a;digitalRead() C&…

京东获得JD商品详情 API 返回值说明||京东API接口

item_get-获得JD商品详情 .jd.item_get 公共参数 名称类型必须描述keyString是调用key&#xff08;必须以GET方式拼接在URL中&#xff09;secretString是调用密钥api_nameString是API接口名称&#xff08;包括在请求地址中&#xff09;[item_search,item_get,item_search_sh…

Halcon相机标定

1&#xff0c;前言。 相机的成像过程实质上是坐标系的转换。首先空间中的点由“世界坐标系”转换到“相机坐标系”&#xff0c;然后再将其投影到成像平面&#xff08;图像物理坐标系&#xff09;&#xff0c;最后再将成像的平面上的数据转换为图像像素坐标系。但是由于透镜的制…

学习星开源在线考试教育系统

学习星开源考试系统 项目介绍 项目概述&#xff1a; 学习星在线考试系统是一款基于Java和Vue.js构建的前后端分离的在线考试解决方案。它旨在为教育机构、企业和个人提供一个高效、便捷的在线测试平台&#xff0c;支持多种题型&#xff0c;包括但不限于单选题、多选题、判断…

趣味魔法项目 LinuxPDF —— 在 PDF 中启动一个 Linux 操作系统

最近&#xff0c;一位开源爱好者开发了一个LinuxPDF 项目&#xff08;ading2210/linuxpdf: Linux running inside a PDF file via a RISC-V emulator&#xff09;&#xff0c;它的核心功能是在一个 PDF 文件中启动并运行 Linux 操作系统。它通过巧妙地使用 PDF 文件格式中的 Ja…

k8s的安装

1. k8s的安装 192.168.48.6 master01 192.168.481.6 node01 192.168.48.26 node02 三台机器一起操作 1.swapoff -a &#xff1a;关闭交换分区 2. iptables -F && iptables -t nat -F && iptables -t mangle -F && iptables -X 3. cat > /etc/sy…

Sentinel 持久化配置

前言 在微服务架构中&#xff0c;Sentinel 是一个非常流行的流量控制和熔断组件&#xff0c;它可以帮助我们保护系统免受高流量的冲击。然而&#xff0c;Sentinel 的配置在默认情况下是不持久化的&#xff0c;这意味着一旦服务重启&#xff0c;所有配置就会丢失。为了解决这个…

不到1M的工具,使用起来非常丝滑!

今天给大家推荐两款电脑上超实用的小软件&#xff0c;分别是倒计时工具和关机助手&#xff0c;用起来特别顺手&#xff0c;希望能帮到大家。 关机助手 帮你自动关机 先说说关机助手。这款软件简直太方便了&#xff01;它是一款免安装的小工具&#xff0c;体积超小&#xff0c;…

day9手机创意软件

趣味类 in:记录趣味生活&#xff08;通用&#xff09; 魔漫相机&#xff1a;真人变漫画&#xff08;通用&#xff09; 活照片&#xff1a;让照片活过来&#xff08;通用&#xff09; 画中画相机&#xff1a;与众不同的艺术 年龄检测仪&#xff1a;比一比谁更年轻&#xf…

【前端 DevOps】GitHub Actions 与 GitLab CI 实战:实现前端项目的自动化测试与部署

网罗开发 &#xff08;小红书、快手、视频号同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企业从事人工智能项目研发管理工作&#xff0c;平时热衷于分享各种编程领域的软硬技能知识以及前沿技术&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…

无耳科技 Solon v3.0.8 发布,Java 企业级应用开发框架

Solon 框架&#xff01; Solon 是新一代&#xff0c;Java 企业级应用开发框架。是杭州无耳科技有限公司的“根级”开源项目&#xff08;最近“杭州六小龙”很火啊&#xff0c;我们也是杭州的哦&#xff09;。从零开始构建&#xff08;No Spring、No Java-EE、No Servlet&#…

Flutter 异步编程利器:Future 与 Stream 深度解析

目录 一、Future&#xff1a;处理单次异步操作 1. 概念解读 2. 使用场景 3. 基本用法 3.1 创建 Future 3.2 使用 then 消费 Future 3.3 特性 二、Stream&#xff1a;处理连续异步事件流 1. 概念解读 2. 使用场景 3. 基本用法 3.1 创建 Stream 3.2 监听 Stream 3.…

Agents Go Deep 智能体深入探索

Agents Go Deep 智能体深入探索 核心事件 OpenAI发布了一款先进的智能体“深度研究”&#xff0c;它能借助网络搜索和推理生成研究报告。 最新进展 功能特性&#xff1a;该智能体依据数百个在线资源生成详细报告&#xff0c;目前仅支持文本输出&#xff0c;不过很快会增加对图…

STM32单片机芯片与内部85 RS232 RS485 UART ISP下载硬件选择 电路设计 IO分配

目录 一、UART 1、硬件选择 2、电路设计 3、IO分配 4、其他设计 二、RS232 1、硬件选择 2、电路设计 3、IO分配 4、其他设计 三、RS485 1、硬件选择 2、电路设计 3、IO分配 4、其他设计 四、ISP下载 一、UART 1、硬件选择 一般选择CH340完成STM32的IO电平与US…

期权帮 | 场外个股期权可以做吗,风险高吗?

锦鲤三三每日分享期权知识&#xff0c;帮助期权新手及时有效地掌握即市趋势与新资讯&#xff01; 场外个股期权可以做吗&#xff0c;风险高吗? 场外个股期权&#xff0c;就是在正式的交易所之外进行交易的个股期权。 注&#xff1a;这里的“场外”指的是这类交易不在像沪深…

【DeepSeek】deepseek可视化部署

目录 1 -> 前文 2 -> 部署可视化界面 1 -> 前文 【DeepSeek】DeepSeek概述 | 本地部署deepseek 通过前文可以将deepseek部署到本地使用&#xff0c;可是每次都需要winR输入cmd调出命令行进入到命令模式&#xff0c;输入命令ollama run deepseek-r1:latest。体验很…

USART串口协议

USART串口协议 文章目录 USART串口协议1. 通信接口2.串口通信2.1硬件电路2.2电平标准2.3串口参数及时序&#xff08;软件部分&#xff09; 3.USART串口外设3.1串口外设3.2USART框图3.3USART基本结构3.4数据帧 4.输入电路4.1起始位侦测4.2数据采样 5.波特率发生器6.相关函数介绍…

2025 西湖论剑wp

web Rank-l 打开题目环境&#xff1a; 发现一个输入框&#xff0c;看一下他是用上面语言写的 发现是python&#xff0c;很容易想到ssti 密码随便输&#xff0c;发现没有回显 但是输入其他字符会报错 确定为ssti注入 开始构造payload&#xff0c; {{(lipsum|attr(‘global…

twisted实现MMORPG 游戏数据库操作封装设计与实现

在设计 MMORPG&#xff08;大规模多人在线角色扮演游戏&#xff09;时&#xff0c;数据库系统是游戏架构中至关重要的一部分。数据库不仅承担了游戏中各种数据&#xff08;如玩家数据、物品数据、游戏世界状态等&#xff09;的存储和管理任务&#xff0c;还必须高效地支持并发访…

PyCharm 批量替换

选择替换的内容 1. 打开全局替换窗口 有两种方式可以打开全局替换窗口&#xff1a; 快捷键方式&#xff1a; 在 Windows 或 Linux 系统下&#xff0c;按下 Ctrl Shift R。在 Mac 系统下&#xff0c;按下 Command Shift R。菜单操作方式&#xff1a;点击菜单栏中的 Edit&…