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

宜春网站建设哪家专业专门做门业的网站

宜春网站建设哪家专业,专门做门业的网站,做微信公众号整合网站,建设官网登录题目 给定一个候选人编号的集合 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的每个数字在每个组合中只能使用 一次 。 注意:解集不能包含重复的组合。 原题链接:https://leetc…

题目

给定一个候选人编号的集合 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。

candidates 中的每个数字在每个组合中只能使用 一次 。

注意:解集不能包含重复的组合。

原题链接:https://leetcode.cn/problems/combination-sum-ii/description/

思路

dfs回溯。先对 candidates 进行排序。每次选定一个数字,然后 target 减去该数字,接着继续dfs。直到找到下一个数字刚好等于剩余target,此时刚好找到一种组合;如果下一个数字大于剩余target,则直接返回。
排序主要是为了方便剪枝。作用体现在两方面:

  1. 当 下一个数字大于剩余target时,再下一个数字也一定大于剩余target。
  2. 假如当前数字之前被选过了,即不是第一次选该数字,则也可以提前剪枝,避免重复组合。
  • 复杂度分析
    • 时间复杂度 O(2^n)。每个数字都有选或不选的可能。
    • 空间复杂度 O(n)。空间复杂度取决于递归的栈深度。

代码

class Solution {
public:vector<vector<int>> result;
public:vector<vector<int>> combinationSum2(vector<int>& candidates, int target) {sort(candidates.begin(), candidates.end());vector<int> temp;backtrace(candidates, temp, 0, target);return result;}void backtrace(vector<int>& candidates, vector<int>& temp, int start, int target) {if (target == 0) {result.push_back(temp);return;}for (int i = start; i < candidates.size(); i++) {if (i > start && candidates[i] == candidates[i - 1]) {continue;}if (candidates[i] > target) {break;}temp.push_back(candidates[i]);backtrace(candidates, temp, i + 1, target - candidates[i]);temp.pop_back();}}
};
http://www.yayakq.cn/news/166637/

相关文章:

  • 深圳手机端网站建设设计公司深圳房产备案查询官网
  • 专门做汽车配件保养的网站谷歌seo网站推广
  • 宣城市建设监督管理局网站下载东莞网站设地
  • 做网站的装饰标语淄博网站建设选择臻动传媒
  • 京东优惠劵网站怎么做wordpress 登录页面变了
  • seo优化介绍英文seo是什么
  • 专注七星彩网站开发出租前端开发一年可以挣多少钱
  • 网站互动设计方式免费定制开发软件
  • 服务器访问不了网站北京口碑最好的教育机构
  • 宝坻区建设路小学网站营销网站优点
  • 网站开发与维护介绍可信网站申请
  • 电商网站设计公司可去亿企邦网站收录需要多久
  • 字体设计网站有哪些免费网站cms系统排名
  • 建一个网站怎么赚钱制作个人网页作品
  • 容桂企业网站建设开发公司设计部工作建议
  • 虚拟网站php专业型wordpress图片视频分享代码
  • 把网站打包微信小程序宁德网站设计
  • 展览公司网站模板百度会收录双域名的网站么
  • 直播型网站开发wordpress主题带中心
  • 如何进入网站sem可以为网站建设做什么
  • 长沙建站官网语言网站开发企业
  • 华为网站推广策略手表网
  • 那些做刷客的网站crm系统登录界面
  • 凡科做的网站不能被收录《网站建设》项目实训报告
  • 设计建设网站哪家好湖人排名最新
  • 淘宝客网站备案教程海外推广平台有哪些?
  • 手机网站主页面文艺网站开发工资怎么样
  • 电商网站开发用什么语言关键词搜索查询
  • 淄博网站建设开发搜索引擎优化介绍
  • 如何为企业做网站廊坊seo排名霸屏