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

招聘网站分析如何做中国工程网查询

招聘网站分析如何做,中国工程网查询,万网云虚拟主机上传网站,dw做网站背景图片设置216. 组合总和 III39. 组合总和40. 组合总和 II46. 全排列47. 全排列 II77. 组合 78. 子集 90. 子集 II 以上是力扣设计相关问题的题目。排列组合还是子集问题无非就是从序列 nums 中以给定规则取若干元素,主要有以下几类: 元素无重不可复选&#xff0…
216. 组合总和 III
39. 组合总和
40. 组合总和 II
46. 全排列
47. 全排列 II
77. 组合

78. 子集

90. 子集 II

以上是力扣设计相关问题的题目。排列组合还是子集问题无非就是从序列 nums 中以给定规则取若干元素,主要有以下几类:

  1. 元素无重不可复选,即 nums 中的元素都是唯一的,每个元素最多只能被使用一次,这也是最基本的形式。
  2. 元素可重不可复选,即 nums 中的元素可以存在重复,每个元素最多只能被使用一次。
  3. 元素无重可复选,即 nums 中的元素都是唯一的,每个元素可以被使用若干次。

以组合为例:

1.如果输入 nums = [2,3,6,7],和为 7 的组合应该只有 [7]

2.如果输入 nums = [2,5,2,1,2],和为 7 的组合应该有两种 [2,2,2,1] 和 [5,2]

3.如果输入 nums = [2,3,6,7],和为 7 的组合应该有两种 [2,2,3] 和 [7]

上面用组合问题举的例子,但排列、组合、子集问题都可以有这三种基本形式,所以共有 9 种变化。

除此之外,题目也可以再添加各种限制条件,比如让你求和为 target 且元素个数为 k 的组合,那这么一来又可以衍生出一堆变体,所以一般笔试很喜欢出这种题。

但无论怎么变化,其本质就是穷举所有解,而这些解呈现树形结构,使用回溯算法框架再稍微修改一些细节即可把这些问题一网打尽

回溯算法框架代码如下:

import java.util.ArrayList;
import java.util.List;public class BacktrackExample {private List<List<Object>> result = new ArrayList<>();public void backtrack(List<Object> path, List<Object> choices) {if (满足结束条件(path)) {result.add(new ArrayList<>(path));return;}for (Object choice : choices) {// 做选择path.add(choice);// 递归backtrack(path, choices);// 撤销选择path.remove(path.size() - 1);}}private boolean 满足结束条件(List<Object> path) {// 这里实现满足结束条件的逻辑return false; // 示例返回,替换为实际逻辑}public List<List<Object>> getResult() {return result;}}

问题一:当元素无重不可复选时,即 nums 中的元素都是唯一的,每个元素最多只能被使用一次:

// 组合/子集问题回溯算法框架
void backtrack(int[] nums, int start) {// 回溯算法标准框架for (int i = start; i < nums.length; i++) {// 做选择track.addLast(nums[i]);// 注意参数backtrack(nums, i + 1);// 撤销选择track.removeLast();}
}// 排列问题回溯算法框架
void backtrack(int[] nums) {for (int i = 0; i < nums.length; i++) {// 剪枝逻辑if (used[i]) {continue;}// 做选择used[i] = true;track.addLast(nums[i]);backtrack(nums);// 撤销选择track.removeLast();used[i] = false;}
}

 问题二:元素可重不可复选,即 nums 中的元素可以存在重复,每个元素最多只能被使用一次,其关键在于排序和剪枝

Arrays.sort(nums);
// 组合/子集问题回溯算法框架
void backtrack(int[] nums, int start) {// 回溯算法标准框架for (int i = start; i < nums.length; i++) {// 剪枝逻辑,跳过值相同的相邻树枝if (i > start && nums[i] == nums[i - 1]) {continue;}// 做选择track.addLast(nums[i]);// 注意参数backtrack(nums, i + 1);// 撤销选择track.removeLast();}
}Arrays.sort(nums);
// 排列问题回溯算法框架
void backtrack(int[] nums) {for (int i = 0; i < nums.length; i++) {// 剪枝逻辑if (used[i]) {continue;}// 剪枝逻辑,固定相同的元素在排列中的相对位置if (i > 0 && nums[i] == nums[i - 1] && !used[i - 1]) {continue;}// 做选择used[i] = true;track.addLast(nums[i]);backtrack(nums);// 撤销选择track.removeLast();used[i] = false;}
}

问题三:元素无重可复选,即 nums 中的元素都是唯一的,每个元素可以被使用若干次,只要删掉去重逻辑即可:

// 组合/子集问题回溯算法框架
void backtrack(int[] nums, int start) {// 回溯算法标准框架for (int i = start; i < nums.length; i++) {// 做选择track.addLast(nums[i]);// 注意参数backtrack(nums, i);// 撤销选择track.removeLast();}
}// 排列问题回溯算法框架
void backtrack(int[] nums) {for (int i = 0; i < nums.length; i++) {// 做选择track.addLast(nums[i]);backtrack(nums);// 撤销选择track.removeLast();}
}

只要从树的角度思考,这些问题看似复杂多变,实则改改 base case 就能解决。只要熟悉了该框架,再细致了解一下细节问题,相信排列组合子集问题都不是问题。

http://www.yayakq.cn/news/486377/

相关文章:

  • 江门网站建设自助建站阿里云做网站视频教程
  • 动易网站系统怎么样哪个网站可以悬赏做图
  • 素材解析网站搭建门户网站优化
  • 四川旅游seo整站优化网站诊断结论
  • 上海废弃物备案网站塘沽做网站公司
  • 化妆品公司网站模板国外搜索引擎
  • 连连建设跨境电商网站哪些网站容易被百度收录
  • 辽宁丹东建设工程信息网站网站后台常用密码
  • 广州网站建设选哪家wordpress转发分享插件
  • 成都网站开发建设推广海尔网站建设的基本情况
  • 官方在家做兼职的网站建筑人才网评职称
  • 网站建设合同报价单 模板下载建设网站的法律声明
  • 网页制作免费网站建设网站设计开发软件网页美化工具
  • 做数据权威的网站图片设计软件免费版
  • 辽宁省营商环境建设监督局网站2345软件管家
  • 泰州做网站软件秦皇岛市网站建设
  • 如何建立网站或网页昆明旅行社网站开发
  • 网站需求列表wordpress for gae
  • 做淘宝网站目的网站建设方案书腾讯云
  • 天津网站建设定做青岛做网站价格
  • 网站的pr手机怎么防止网站自动跳转
  • 营销型网站怎么收费x wordpress theme
  • 动易网站后台山西中交建设工程招标有限公司网站
  • 电商网站建设包括哪些内容株洲新区发布
  • 网站开发需要学些什么?做网站 简单外包
  • 建设企业网站需要了解什么互联网的发展
  • 网站地市频道建设微信公众号里面免费做网站
  • 发帖网站百度收率高的ppt模板制作免费
  • 申请网站做自己的产品京东网站建设现状分析
  • 手机wap网站怎样从微信公众号打开网站密码如何找回