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

咸阳兼职做网站app客户端网站建设方案

咸阳兼职做网站,app客户端网站建设方案,wordpress修订管理,建设网站服务器1组合 给定两个整数 n 和 k#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 示例 1#xff1a; 输入#xff1a;n 4, k 2 输出#xff1a; [[2,4],[3,4],[2,3],[1,2],[1,3],[1,4], ] 示例 2#xff1a; 输入#xff1a;n …1组合 给定两个整数 n 和 k返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 示例 1 输入n 4, k 2 输出 [[2,4],[3,4],[2,3],[1,2],[1,3],[1,4], ] 示例 2 输入n 1, k 1 输出[[1]] 提示 1 n 201 k n 思路 回溯法三部曲 递归函数的返回值以及参数 返回值无使用类成员变量result存储最终结果。参数backtracking函数接受三个参数分别是n1到n的范围、k组合的长度、startIndex当前处理的起始位置。 回溯函数终止条件 当path的长度等于k时将当前path加入结果集然后返回。 单层搜索的过程解题思路 从startIndex到n的范围内遍历所有可能的数字。将当前处理的数字i添加到path中表示选择了这个数字。进行递归调用backtracking函数继续向下搜索但是startIndex更新为i1表示下一次搜索时不再考虑当前数字i之前的数字。当递归返回后将当前处理的数字i从path中弹出进行回溯操作尝试其他可能的组合。通过不断选择、判断和回溯操作搜索所有符合条件的组合最终将结果存储在result中并返回。 代码 class Solution { private:vectorvectorint result; // 存放符合条件结果的集合vectorint path; // 用来存放符合条件结果void backtracking(int n, int k, int startIndex) {if (path.size() k) { // 如果路径长度等于k将路径加入结果集result.push_back(path);return;}for (int i startIndex; i n; i) {path.push_back(i); // 处理节点backtracking(n, k, i 1); // 递归path.pop_back(); // 回溯撤销处理的节点}} public:vectorvectorint combine(int n, int k) {backtracking(n, k, 1); // 从1开始尝试组合return result; // 返回结果集} }; 2 组合总和 III 找出所有相加之和为 n 的 k 个数的组合且满足下列条件 只使用数字1到9每个数字 最多使用一次  返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次组合可以以任何顺序返回。 示例 1: 输入: k 3, n 7 输出: [[1,2,4]] 解释: 1 2 4 7 没有其他符合的组合了。 示例 2: 输入: k 3, n 9 输出: [[1,2,6], [1,3,5], [2,3,4]] 解释: 1 2 6 9 1 3 5 9 2 3 4 9 没有其他符合的组合了。 示例 3: 输入: k 4, n 1 输出: [] 解释: 不存在有效的组合。 在[1,9]范围内使用4个不同的数字我们可以得到的最小和是1234 10因为10 1没有有效的组合。提示: 2 k 91 n 60 思路 递归函数的返回值和参数 返回值无结果保存在类成员变量result中。参数backtracking函数接受四个参数分别是目标和targetSum、组合的长度k、当前组合的和sum、当前可以选数字的最小索引startIndex。 回溯函数的终止条件 如果当前的和sum超过了目标和targetSum则不再搜索直接返回。如果当前组合的长度path等于k且当前的和sum等于目标和targetSum则将当前组合加入结果集合result。 单层搜索的过程解题思路 从startIndex开始遍历所有可选的数字。将当前数字i加入组合path中累加当前和sum。递归调用backtracking函数继续搜索下一个数字。递归返回后从当前和sum中减去当前数字i从组合path中移除当前数字i。通过不断的加入数字、递归搜索和移除数字最终得到所有满足条件的组合。 代码 class Solution { private:vectorvectorint result; // 存放结果集合vectorint path; // 用来存放当前组合// 回溯函数生成和为 targetSum长度为 k 的数字组合void backtracking(int targetSum, int k, int sum, int startIndex) {// 如果当前的sum已经超过了目标值则不再搜索直接返回if (sum targetSum) return;// 达到组合长度要求且总和等于目标值时将当前组合加入结果集合if (path.size() k) {if (sum targetSum) result.push_back(path);return;}// 从 startIndex 开始遍历可选数字for (int i startIndex; i 9; i) {sum i; // 统计当前总和path.push_back(i); // 将当前数字加入组合中backtracking(targetSum, k, sum, i 1); // 递归处理下一个数字sum - i; // 回溯撤销当前数字的处理path.pop_back(); // 回溯撤销当前数字的处理}}public:// 组合函数生成和为 n长度为 k 的数字组合vectorvectorint combinationSum3(int k, int n) {backtracking(n, k, 0, 1); // 回溯搜索组合return result; // 返回结果集合} }; 3组合总和 给你一个 无重复元素 的整数数组 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 302 candidates[i] 40candidates 的所有元素 互不相同1 target 40 思路 递归函数的返回值和参数 返回值无结果保存在类成员变量result中。参数backtracking函数接受四个参数分别是候选数字数组candidates、目标和target、当前组合的和sum、当前可以选数字的最小索引startIndex。 回溯函数的终止条件 如果当前的和sum超过了目标和target则不再搜索直接返回。如果当前组合的和sum等于目标和target则将当前组合加入结果集合result。 单层搜索的过程解题思路 从startIndex开始遍历候选数字数组candidates。将当前数字加入组合path中累加当前和sum。递归调用backtracking函数继续搜索当前数字。递归返回后从当前和sum中减去当前数字从组合path中移除当前数字。通过不断的加入数字、递归搜索和移除数字最终得到所有满足条件的组合。 代码 class Solution { private:vectorvectorint result; // 存放结果集合vectorint path; // 用来存放当前组合void backtracking(vectorint candidates, int target, int sum, int startIndex) {if (sum target) {return; // 当前组合和超过目标值终止搜索}if (sum target) {result.push_back(path); // 当前组合和等于目标值加入结果集合return;}for (int i startIndex; i candidates.size(); i) {sum candidates[i]; // 统计当前总和path.push_back(candidates[i]); // 将当前数字加入组合中backtracking(candidates, target, sum, i); // 递归处理当前数字sum - candidates[i]; // 回溯撤销当前数字的处理path.pop_back(); // 回溯撤销当前数字的处理}}public:vectorvectorint combinationSum(vectorint candidates, int target) {backtracking(candidates, target, 0, 0); // 回溯搜索组合return result; // 返回结果集合} };
http://www.dnsts.com.cn/news/177625.html

相关文章:

  • 地方网站怎么做挣钱公司网站做优化
  • 什么是网站托管罗定网站优化
  • 专业营销型网站建设费用管理咨询公司业务类型
  • 北京移动网站建设市政工程建设规范免费下载网站
  • 网站定制开发特点wordpress结构化数据
  • p2p网站的建设个人网站备案后内容可以改么
  • 温州网站维护工作安阳市网站建设
  • 安徽手机网站建设东莞市门户网站建设怎么样
  • seo如何提高网站排名校园网站建设的困难
  • 成都网站搭建公司哪家便宜网站建设与规划实训报告
  • 大兴网站建设公司百度网站站长工具
  • 有没有专门做特产的网站最新新闻热点头条
  • 集团网站建设运营公司建设厅网站怎么打印不出来
  • 如何开发手机端网站wordpress模板chinaz
  • 建建建设网站公司网站泰兴做网站电话
  • 重庆网站建设微信开发外贸开发网站建设
  • 合肥响应式网站建设方案高端网站建设seo
  • 山东机关建设网站道德模范wap门户网站
  • 如何制作手机网站模板ppt内容素材大全
  • 做查询网站 发布数据做网站想注册商标是哪一类
  • 利用淘宝视频服务做视频网站杭州网站设计精选柚v米科技
  • 互联网网站建设挣钱吗个人律师网站模板
  • 网站权重排行榜用自己的电脑做服务器建网站
  • 什么网站是用php做的免费制作企业小程序
  • 用php做一网站有哪些南宁网页制作设计营销
  • 个人免费建站软件wordpress整站
  • 网站建成之后应该怎么做平面广告设计网址
  • 相亲网站用什么做的汕头网络推广seo方案
  • 网站交互效果汕头免费模板建站
  • 河北建设银行官网招聘网站网页让升级浏览器