Day26 第七章 回溯算法part05

embedded/2025/2/24 11:34:41/

一. 学习文章及资料

  • 491.递增子序列
  • 46.全排列
  • 47.全排列 II

二. 学习内容

1. 递增子序列

(1) 题目要点:

  • 递增子序列,
  • 数组中可能含有重复元素

(2) 解题思路:

如下一选取元素不是递增或使用过,则跳过这一分支,用set记录已使用元素以达去重效果

class Solution {List<List<Integer>> result=new ArrayList<>();List<Integer> path=new LinkedList<>();void backtracking(int[] nums,int startIndex){if(path.size()>=2){result.add(new ArrayList(path));}HashSet<Integer> hs=new HashSet<>();for(int i=startIndex;i<nums.length;i++){if(!path.isEmpty()&&path.get(path.size()-1)>nums[i]||hs.contains(nums[i])){//如下一个数不是递增或使用过,则跳过continue;}hs.add(nums[i]);path.add(nums[i]);backtracking(nums,i+1);path.removeLast();}return;}public List<List<Integer>> findSubsequences(int[] nums) {backtracking(nums,0);return result;}
}

2. 全排列

(1) 解题要点:

  • 没有重复数字
  • 返回其所有可能的全排列

(2) 解题思路:

首先排列是有序的,也就是说 [1,2] 和 [2,1] 是两个集合,这和之前分析的子集以及组合所不同的地方。可以看出元素1在[1,2]中已经使用过了,但是在[2,1]中还要在使用一次1,所以处理排列问题就不用使用startIndex了,每层i都从0开始,使用used数组记录使用情况

class Solution {List<List<Integer>> result=new ArrayList<>();List<Integer> path=new LinkedList<>();void backtracking(int[] nums,boolean[] used){if(path.size()==nums.length){result.add(new ArrayList(path));}for(int i=0;i<nums.length;i++){if(used[i]==true) continue;used[i]=true;path.add(nums[i]);backtracking(nums,used);path.removeLast();used[i]=false;}return;}public List<List<Integer>> permute(int[] nums) {boolean[] used=new boolean[nums.length];backtracking(nums,used);return result;}
}

3. 全排列 II

(1) 题目要点:

  • 包含重复数字
  • 返回所有不重复的全排列

(2) 题目思路:

以示例中的 [1,1,1]为例 (为了方便举例,已经排序)抽象为一棵树,去重过程如图:

47.全排列II2

图中我们对同一树层,前一位(也就是nums[i-1])如果使用过,那么就进行去重。

要强调的是去重一定要对元素进行排序,这样我们才方便通过相邻的节点来判断是否重复使用了

组合问题和排列问题是在树形结构的叶子节点上收集结果,而子集问题就是取树上所有节点的结果

class Solution {List<List<Integer>> result=new ArrayList<>();List<Integer> path=new LinkedList<>();void backtracking(int[] nums,boolean[] used){if(path.size()==nums.length){result.add(new ArrayList(path));return;}for(int i=0;i<nums.length;i++){// used[i - 1] == true ,说明同一树枝nums[i - 1]使用过// used[i - 1] == false,说明同一树层nums[i - 1]使用过if(i>0&&nums[i]==nums[i-1]&&used[i-1]==false) continue;//防止一种数字重复使用if(used[i]==false){//每个元素数只能用一次,防止重复使用path.add(nums[i]);used[i]=true;backtracking(nums,used);used[i]=false;path.removeLast();}}}public List<List<Integer>> permuteUnique(int[] nums) {boolean[] used = new boolean[nums.length];Arrays.sort(nums); backtracking(nums,used);return result;}
}


http://www.ppmy.cn/embedded/164813.html

相关文章

DeepSeek生成思维导图

一、准备阶段 工具准备 安装思维导图软件&#xff08;推荐XMind/MindMaster/在线工具如ProcessOn&#xff09; 打开DeepSeek官网或集成平台&#xff08;https://www.deepseek.com/&#xff09; 明确需求 确定思维导图核心主题&#xff08;如"碳中和实施方案"&…

开源一个可以调RGB三色的小灯棒子

开源一个可以调灯的小灯棒子。 主控用的STC8G1K08A-SOP8&#xff0c;RGB三色灯是WS2812B。 开源到立创开源广场了&#xff0c;可以直接进入下方链接&#xff0c;那边可以直接查看原理图和PCB。 一个可调RGB三色的小灯棒子 - 立创开源硬件平台一个可调RGB三色的小灯棒子https…

Git版本控制系统---本地操作(万字详解!)

目录 git基本配置 认识工作区、暂存区、版本库 添加文件--情况一&#xff1a; 添加文件-情况二: 修改文件: 版本回退&#xff1a; git基本配置 1.初始化本地仓库&#xff0c;注意&#xff1a;一定要在一个目录下进行&#xff0c;一般都是新建一个文件夹&#xff0c;在文件…

Vulhub靶机 Apache Druid(CVE-2021-25646)(渗透测试详解)

一、开启vulhub环境 docker-compose up -d 启动 docker ps 查看开放的端口 1、漏洞范围 在Druid0.20.0及更低版本中 二、访问靶机IP 8888端口 1、点击Load data进入新界面后&#xff0c;再点击local disk按钮。 2、进入新界面后&#xff0c;在标红框的Base directory栏写上…

财务运营域——电子影像系统设计

摘要 文章主要介绍了电子影像系统的设计与应用。随着企业规模扩大和业务复杂化&#xff0c;传统纸质文档管理方式暴露出诸多问题&#xff0c;电子影像技术应运而生。它通过数字化扫描、存储和管理纸质文档&#xff0c;实现高效检索、实时共享、安全存储和流程自动化&#xff0…

视觉应用工程师(面试)

视觉应用工程师&#xff08;面试&#xff09; 1.自我介绍、会的技能、项目 2.相机和机械手调试过程 检查硬件&#xff0c;看软件驱动是否链接&#xff0c;调节相机和镜头保证能够识别这个物料&#xff0c;看接口和通讯是否正常&#xff0c;如&#xff1a;波特率&#xff0c;数…

SSI用量子计算来玩AI

刚到家&#xff0c;早上说今天回来要写SSI为什么这么牛B&#xff0c;那就必须得写 SSI是什么公司&#xff1f; Safe Super Intelligence 就是中间这个秃子的公司 ilya 前openAI 首席科学家(现在的mark chen确实有点水) Daniel Gross、Ilya Sutskever、Daniel Levy&#xff…

使用visual studio对dmp文件进行调试(winform)

网上有很多关于使用vs对dmp的调试教程&#xff0c;不过大多比较简略&#xff0c;为便于日后查阅&#xff0c;综合自己调研的过程&#xff0c;特此书写整个调试流程。 终极目标&#xff1a;根据dmp文件&#xff0c;找到程序异常位置调试工具&#xff1a;visual studio 2022 ent…