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

组合总和II(力扣40)

这道题的难点就在于题目所给的集合中有重复的数字,我们需要进行去重操作。首先明确去重指的是去重哪一部分。注意并不是对递归的集合去重,而是对当前集合的遍历进行去重。这么说可能有点抽象,举个例子:假设集合为1,1,2,3,4,我们第一次选1,递归集合时,我们仍可以选择第二个1。但是在第一次选第二个1时,在往下选,就会出现很多与第一次选第一个1时相同的组合。所以在每一层递归函数的for循环中我们需要进行去重。不过,我们需要判断这个重复出现的数字是在当前这层递归的for循环中还是在下一层递归的for循环中。于是,我们创建了一个数组,标识这些集合中的数字是否被使用过,如果被使用过,说明是在上一层递归中被使用,如果没有被使用,说明是在当前这一层递归的for循环中。大家可以结合我下面的代码及详细注释理解。

代码及详细注释如下:

class Solution {
public:vector<int> path;vector<vector<int>> result;void backtracking(vector<int>& candidates,int target,int sum,int start,vector<int>& used){//剪枝if(sum > target){return;}//终止条件if(sum == target){result.push_back(path);return;}for(int i = start;i < candidates.size();i++){//去重if(i > 0 && candidates[i] == candidates[i - 1] && used[i - 1] == 0){continue;}path.push_back(candidates[i]);sum += candidates[i];used[i] = 1;backtracking(candidates,target,sum,i + 1,used);//回溯path.pop_back();sum -= candidates[i];used[i] = 0;}return;}vector<vector<int>> combinationSum2(vector<int>& candidates, int target) {//创建一个数组,该数组下标对应集合中元素的下标,表示集合中各个下标对应的数字有没有使用过vector<int> used(candidates.size(),0);sort(candidates.begin(),candidates.end());backtracking(candidates,target,0,0,used);return result;}
};

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

相关文章:

  • 基于HTML生成网页有什么优势
  • php 接入扣子的 token获取
  • Redis02 - 持久化
  • 【力扣】240.搜索二维矩阵 II
  • RabbitMQ 从入门到精通:从工作模式到集群部署实战(二)
  • 编程AI深度实战:大模型哪个好? Mistral vs Qwen vs Deepseek vs Llama
  • 11.kafka开启jmx
  • 基于钉钉API的连接器实现:企业数据集成与自动化管理
  • JAVA 二维列表的基础操作与异常
  • 将仓库A分支同步到仓库B分支,并且同步commit提交
  • 使用java代码操作rabbitMQ收发消息
  • mysql8安装时提示-缺少Microsoft Visual C++ 2019 x64 redistributable
  • WindowsServer搭建内网Gitea【中文更方便使用】
  • leetcode 907. 子数组的最小值之和
  • WordPress自定义.js文件排序实现方法
  • 摄像头模块烟火检测
  • 【拼十字——树状数组】
  • 脚手架开发【实战教程】prompts + fs-extra
  • Fiddler Classic(HTTP流量代理+半汉化)
  • 基于yolov11的阿尔兹海默症严重程度检测系统python源码+onnx模型+评估指标曲线+精美GUI界面
  • 玩转Docker | 使用Docker部署httpd服务
  • 力扣1022. 从根到叶的二进制数之和(二叉树的遍历思想解决)
  • 排序算法--基数排序
  • 【AIGC魔童】DeepSeek核心创新技术(二):MLA
  • Mac: docker安装以后报错Command not found: docker
  • Golang 并发机制-7:sync.Once实战应用指南
  • react关于手搓antd pro面包屑的经验(写的不好请见谅)
  • Android修行手册-五种比较图片相似或相同
  • 设计模式.
  • 使用PyCharm创建项目以及如何注释代码