LeetCode 算法:组合总和 c++

原题链接🔗:组合总和
难度:中等⭐️⭐️

题目

给你一个 无重复元素 的整数数组 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. 解题思路
  • LeetCode 上的 “组合总和”(Combination Sum)问题是一个典型的回溯算法问题。这个问题要求你从给定的候选数字数组中找出所有可能的组合,这些组合的元素之和等于给定的目标和。以下是解决这个问题的一种通用思路:

  • 问题描述

    • 给定一个无重复元素的数组 candidates 和一个目标数 target,找出 candidates 中所有可以使数字和为 target 的组合。candidates 中的数字可以无限制重复被选取。
  • 解题思路

    • 回溯算法:使用回溯算法来尝试所有可能的组合。 排序:对 candidates 数组进行排序,这有助于剪枝,因为如果当前元素大于目标数,可以停止当前路径的搜索。
    • 递归函数:定义一个递归函数,该函数接收当前索引 start,当前组合 path,以及当前和 current_sum。
    • 终止条件:如果 current_sum 等于 target,则将当前组合添加到结果列表中。
    • 剪枝:如果 current_sum 超过 target 或者 start 超过数组长度,停止当前路径的搜索。
    • 循环遍历:从 start 开始遍历数组,对于每个元素,将其添加到当前组合中,并递归调用函数,然后回溯(即从当前组合中移除该元素)。
  1. c++ demo
#include <vector>
#include <algorithm>
#include <iostream>void findCombinations(std::vector<int>& candidates, int target, int start, std::vector<int>& current, std::vector<std::vector<int>>& result) {// 如果当前和等于目标,则将当前组合添加到结果中if (target == 0) {result.push_back(current);return;}for (int i = start; i < candidates.size(); ++i) {// 跳过相同的元素以避免重复的组合if (i > start && candidates[i] == candidates[i - 1]) continue;// 如果当前元素大于目标,则不需要继续搜索if (candidates[i] > target) break;// 将当前元素添加到组合中current.push_back(candidates[i]);// 递归调用,使用 i + 1 作为新的起始索引,因为我们可以重复使用相同的元素findCombinations(candidates, target - candidates[i], i, current, result);// 回溯,移除当前元素current.pop_back();}
}std::vector<std::vector<int>> combinationSum(std::vector<int>& candidates, int target) {// 对候选数组进行排序std::sort(candidates.begin(), candidates.end());std::vector<int> current;std::vector<std::vector<int>> result;// 从索引0开始,使用当前数组作为候选数组findCombinations(candidates, target, 0, current, result);return result;
}int main() {std::vector<int> candidates = { 2, 3, 6, 7 };int target = 7;std::vector<std::vector<int>> result = combinationSum(candidates, target);// 打印结果for (const auto& combination : result) {std::cout << "{";for (size_t i = 0; i < combination.size(); ++i) {std::cout << combination[i];if (i < combination.size() - 1) std::cout << ", ";}std::cout << "}" << std::endl;}return 0;
}
  • 输出结果:

{2, 2, 3}
{7}

  1. 代码仓库地址:combinationSum

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LlaMa 2

目录 LlaMa 2 介绍&#xff1a; Llama 的诞生&#xff1a; Llama 2 的训练数据集是如何构建和选择的&#xff1f; Llama 2 在自然语言处理&#xff08;NLP&#xff09;任务中的具体应用案例有哪些&#xff1f; Llama 2 模型在商业应用中的表现如何&#xff0c;有哪些成功案…

认识sm1,sm2,sm3,sm4以及如何在Node.js实现

概述 国密即国家密码局认定的国产密码算法。主要有SM1&#xff0c;SM2&#xff0c;SM3&#xff0c;SM4。密钥长度和分组长度均为128位。 国密算法是指国家密码管理局认定的一系列国产密码算法&#xff0c;包括SM1-SM9以及ZUC等。其中 SM1、SM4、SM5、SM6、SM7、SM8、ZUC等属于…

verilog刷题笔记

1、选择器实现方式 &#xff08;1&#xff09;case语句&#xff0c;注意default &#xff08;2&#xff09;if-else语言&#xff0c;注意else&#xff0c;有优先级 &#xff08;3&#xff09;三元运算符 &#xff1f; &#xff1a; 2、阻塞赋值/非阻塞赋值都是过程性赋值&a…

1千多看图猜成语游戏ACCESS\EXCEL数据库

今天闲来无事想写个代码自己搞定&#xff0c;我不写代码已经很久了&#xff0c;主要是年纪不小了对新技术的学习比较吃力&#xff0c;兴趣也被生活打磨的体无完肤。今天又捡起VB&#xff08;暴露了年纪&#xff09;搞了一下。 当然&#xff0c;很多事情都是这样&#xff0c;自己…

Docker容器——初识Docker,安装以及了解操作命令

一、Docker是什么? 是一个开源的应用容器引擎&#xff0c;基于go语言开发并遵循了apache2.0协议开源&#xff0c;用来管理容器和镜像的工具是在Linux容器里驱动运行应用的开源工具是一种轻量级的“虚拟机” 基于linux内核运行Docker的容器技术可以在一台主机上轻松为任何应用…

【AI教程-吴恩达讲解Prompts】第1篇 - 课程简介

文章目录 简介Prompt学习相关资源 两类大模型原则与技巧 简介 欢迎来到面向开发者的提示工程部分&#xff0c;本部分内容基于吴恩达老师的《Prompt Engineering for Developer》课程进行编写。《Prompt Engineering for Developer》课程是由吴恩达老师与 OpenAI 技术团队成员 I…

webpack生产环境下的配置

css 处理 css提取 下载包 npm i -D mini-css-extract-plugin 配置 module: {rules: [{test: /\.css$/,use: [// style-loader, // 创建style标签&#xff0c;将样式加入js文件MiniCssExtractPlugin.loader, // 提取js中的css成单独的文件css-loader,]}, ]},plugins: [new H…

react 18中,使用useRef 获取其他组件的dom并操作节点,flushSync强制同步更新useState

React 不允许组件访问其他组件的 DOM 节点。甚至自己的子组件也不行&#xff01;这是故意的。Refs 是一种脱围机制&#xff0c;应该谨慎使用。手动操作 另一个 组件的 DOM 节点会使你的代码更加脆弱。 相反&#xff0c;想要 暴露其 DOM 节点的组件必须选择该行为。一个组件可以…

鹈鹕优化算法(POA)及其Python和MATLAB实现

鹈鹕优化算法&#xff08;Pelican Optimization Algorithm&#xff0c;简称POA&#xff09;是一种基于仿生学原理的优化算法&#xff0c;灵感来源于大自然中鹈鹕的觅食行为。POA被设计用于解决优化问题&#xff0c;尤其在连续型和离散型的优化问题中展现出了较好的性能。 ### …

单例模式-C#

在C#中实现单例模式&#xff0c;主要目的是确保一个类仅有一个实例&#xff0c;并提供一个全局访问点来获取这个实例。以下是一个简单的单例模式实现示例&#xff0c;它使用了一个私有静态变量来保存类的唯一实例&#xff0c;并提供了一个公有的静态方法来获取这个实例。此外&a…

【Unity C#基础】浅谈List底层逻辑

1.内部实现 List实际是通过数组来实现的&#xff0c;而不是链表。并且没设定初始容量的情况下&#xff0c;初始容量默认为0。 2.扩容 每次容量不够时&#xff0c;数组容量会扩充一倍。按照4、8、16、32、64、128、256……递增。 按照2的指数进行扩容可以为GC减少负担。 每…

CentOS 7 网络配置

如想了解请查看 虚拟机安装CentOS7 第一步&#xff1a;查看虚拟机网络编辑器、查看NAT设置 &#xff08;子网ID&#xff0c;网关IP&#xff09; 第二步&#xff1a;配置VMnet8 IP与DNS 注意事项&#xff1a;子网掩码与默认网关与 第一步 保持一致 第三步&#xff1a;网络配置…

客服新纪元:Transformer模型在自动化客户服务的革命性应用

客服新纪元&#xff1a;Transformer模型在自动化客户服务的革命性应用 随着人工智能技术的飞速发展&#xff0c;自动化客户服务已成为企业提升效率、降低成本的关键途径。Transformer模型&#xff0c;以其在处理序列数据方面的强大能力&#xff0c;正在自动化客户服务领域扮演…

掌握Xcode的魔术:自定义Storyboard的创建与管理

掌握Xcode的魔术&#xff1a;自定义Storyboard的创建与管理 在iOS应用开发中&#xff0c;Storyboard提供了一种直观的方式来设计和管理用户界面。通过Storyboard&#xff0c;开发者可以轻松地构建应用的视图控制器&#xff0c;同时定义它们之间的转换。然而&#xff0c;随着应…

用Pytorch实现线性回归(Linear Regression with Pytorch)

使用pytorch写神经网络的第一步就是需要准备好数据集&#xff0c;设计模型&#xff08;用于计算y_hat&#xff08;y的预测值&#xff09;&#xff09;&#xff0c;构造损失函数和优化器&#xff08;使用PyTorch API&#xff09;&#xff0c;写训练周期&#xff08;前馈&#xf…

Centos7 rpm 安装 Mysql 8.0.28

Centos7 rpm 安装 Mysql 8.0.28 一、检查系统是否已经安装了Mysql 如果安装了则卸载 [rootiZbp1byzaznzn9jncxr010Z /]# rpm -qa | grep mysql[rootiZbp1byzaznzn9jncxr010Z /]# rpm -qa | grep mariadb mariadb-libs-5.5.68-1.el7.x86_64如果安装了 mysql &#xff0c;maria…

2-36 基于matlab的流行学习算法程序

基于matlab的流行学习算法程序。通过GUI的形式将MDS、PCA、ISOMAP、LLE、Hessian LLE、Laplacian、Dissusion MAP、LTSA八种算法。程序以可视化界面进行展示&#xff0c;可直接调用进行分析。多种案例举例说明八种方法优劣&#xff0c;并且可设置自己数据进行分析。程序已调通&…

【12】奇偶数判断

奇偶数判断 题目描述 给定一个整数&#xff0c;判断该数是奇数还是偶数。如果 n n n 是奇数&#xff0c;输出 odd&#xff1b;如果 n n n 是偶数&#xff0c;输出 even。 输入格式 输入仅一行&#xff0c;一个整数 n n n。 输出格式 输出仅一行&#xff0c;如果 n n …

网络安全工作者如何解决网络拥堵

网络如同现代社会的血管&#xff0c;承载着信息的血液流动。然而&#xff0c;随着数据流量的激增&#xff0c;网络拥堵已成为不容忽视的问题&#xff0c;它像是一场数字世界的交通堵塞&#xff0c;减缓了信息传递的速度&#xff0c;扰乱了网络空间的秩序。作为网络安全的守护者…

vue2页面渲染 两个数据一行 怎么渲染

let data[“办公电脑”,“办公纸品”,“个护用品”,“销毁设备”,“桌面文具”,] 在 Vue 2 中&#xff0c;你可以使用 ​v-for​ 指令来遍历数据数组&#xff0c;并使用 CSS 来控制每行显示两个数据项。以下是一个简单的示例&#xff0c;展示了如何在 Vue 2 中实现这个需求&am…