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

代码随想录算法训练营第二十九天|491.递增子序列、46.全排列、47.全排列 II

目录

491.递增子序列

46.全排列

47.全排列 II


491.递增子序列

本题和大家刚做过的 90.子集II 非常像,但又很不一样,很容易掉坑里。 

代码随想录

视频讲解:回溯算法精讲,树层去重与树枝去重 | LeetCode:491.递增子序列_哔哩哔哩_bilibili

题解思路:

本题还是有点坑的,这里的如何记录使用过的数组的方式很容易给人造成误解,具体的解释如下:
1、使用数组来做哈希,初始化数组里面的元素都设置为0,如果设置成全局变量,那么每轮递归的时候相同元素只能使用一次,以[4,6,7,7]来说,不能取到4677这个组合的,显然不符合题意,因为本题不是对排序后的数组进行树层去重的,因此出现相同元素不一定是相邻元素,只能出现一个记录一个。
2、每次递归数组uesd都会重置为0的代码直接嵌套在递归里面,因为树枝不需要去重的,需要及时把使用过的元素重置为0;回溯的时候之前标记为1的地方仍然为1,并没有重置为0。
以上两点的解读就是为什么不把uesd设置为全局变量,使用used[nums[i] + 100] = 0把使用过的元素重置为0,而是直接嵌套在递归里面,可以及时往下搜索的时候及时置为0,不会造成树枝去重的原理,

class Solution {LinkedList<Integer> path = new LinkedList<>();List<List<Integer>> result = new ArrayList<>();public List<List<Integer>> findSubsequences(int[] nums) {backtracking(nums, 0);return result;}public void backtracking(int[] nums, int startIndex){if(path.size() > 1 ) result.add(new LinkedList<Integer>(path));if(startIndex == nums.length) return;int[] used = new int[201]; //使用数组来做哈希,初始化数组里面的元素都设置为0,如果设置成全局变量,那么每轮递归的时候相同元素只能使用一次,以[4,6,7,7]来说,不能取到4677这个组合的,显然不符合题意。因为本题不是对排序后的数组进行树层去重的,因此出现相同元素不一定是相邻元素,只能出现一个记录一个。//具体方式解读为:这里每次递归数组uesd都会重置为0,因为树枝不需要去重的,需要及时把使用过的元素重置为0;回溯的时候之前标记为1的地方仍然为1,并没有重置为0。这就是为什么不把uesd设置为全局变量,使用used[nums[i] + 100] = 0把使用过的元素重置为0,而是直接嵌套在递归里面,可以及时往下搜索的时候及时置为0,不会造成树枝去重的原理,for(int i = startIndex; i < nums.length; i++){if((path.size() != 0 && nums[i] < path.getLast()) || used[nums[i] + 100] == 1 ){continue;}used[nums[i] + 100] = 1;path.add(nums[i]);backtracking(nums, i + 1);path.removeLast();}}
}

46.全排列

本题重点感受一下,排列问题 与 组合问题,组合总和,子集问题的区别。 为什么排列问题不用 startIndex 

代码随想录

视频讲解:组合与排列的区别,回溯算法求解的时候,有何不同?| LeetCode:46.全排列_哔哩哔哩_bilibili

题解思路:

排列和组合问题还是有区别的,和组合最大的区别在于求全排列问题,每层都是从0开始搜索而不是startIndex,需要used数组记录path里都放了哪些元素了!!!最后对听卡哥视频讲解思路,然后自己写出来最好,u1s1听卡哥讲算法是一种享受!!!本题需要注意的一点就是: if(used[i] == true) continue;在每轮递归中求全排列中都是从0开始搜索,需要通过uesd的数组记录path中已经添加过的元素,添加过的元素直接跳过就行

class Solution {LinkedList<Integer> path = new LinkedList<>();List<List<Integer>> result = new ArrayList<>();boolean[] used; //需要used数组记录path里都放了哪些元素了public List<List<Integer>> permute(int[] nums) {used = new boolean[nums.length];backtracking(nums);return result;}public void backtracking(int[] nums){if(path.size() == nums.length){result.add(new LinkedList<Integer>(path));return;}for(int i = 0; i < nums.length; i++){ if(used[i] == true) continue;//在每轮递归中求全排列中都是从0开始搜索,需要通过uesd的数组记录path中已经添加过的元素,添加过的元素直接跳过就行path.add(nums[i]);used[i] = true;backtracking(nums);path.removeLast();used[i] = false;}}
}

47.全排列 II 

本题 就是我们讲过的 40.组合总和II 去重逻辑 和 46.全排列 的结合,可以先自己做一下,然后重点看一下 文章中 我讲的拓展内容。 used[i - 1] == true 也行,used[i - 1] == false 也行

代码随想录

视频讲解:回溯算法求解全排列,如何去重?| LeetCode:47.全排列 II_哔哩哔哩_bilibili

题解思路:

本题需要先把数组进行排序,使得相同的元素相邻才好进行树层去重,具体的注意细节代码中有详细注释,本题容易疑惑的两行代码见如下分析:
1、if(i > 0 && nums[i] == nums[i -1] && used[i - 1] == false) continue; //为了避免以相同元素开头的组合重复添加到结果集中进行树层去重
2、if(used[i] == true) continue; //在每轮递归中求全排列中都是从0开始搜索,需要通过uesd的数组记录path中已经添加过的元素,添加过的元素直接跳过就行

class Solution {LinkedList<Integer> path = new LinkedList<>();List<List<Integer>> result = new ArrayList<>();boolean[] used;public List<List<Integer>> permuteUnique(int[] nums) {used = new boolean[nums.length];Arrays.sort(nums); //需要先把数组进行排序,使得相同的元素相邻才好进行树层去重backtracking(nums);return result;}public void backtracking(int[] nums){if(path.size() == nums.length){result.add(new LinkedList<Integer>(path));return;} for(int i = 0; i < nums.length; i++){if(i > 0 && nums[i] == nums[i -1] && used[i - 1] == false) continue; //为了避免以相同元素开头的组合重复添加到结果集中进行树层去重if(used[i] == true) continue; //在每轮递归中求全排列中都是从0开始搜索,需要通过uesd的数组记录path中已经添加过的元素,添加过的元素直接跳过就行path.add(nums[i]);used[i] = true;backtracking(nums);used[i] = false;path.removeLast();}}
}

相关文章:

代码随想录算法训练营第二十九天|491.递增子序列、46.全排列、47.全排列 II

目录 491.递增子序列 46.全排列 47.全排列 II 491.递增子序列 本题和大家刚做过的 90.子集II 非常像&#xff0c;但又很不一样&#xff0c;很容易掉坑里。 代码随想录 视频讲解&#xff1a;回溯算法精讲&#xff0c;树层去重与树枝去重 | LeetCode&#xff1a;491.递增子序…...

【Kafka】Kafka监控工具Kafka-eagle简介

Kafka-eagle是一种基于Web的开源管理工具&#xff0c;可以用来监控、管理多个Kafka集群。 下面是使用Docker部署Kafka-eagle的步骤&#xff1a; 下载并安装Docker和Docker Compose。 创建文件夹&#xff0c;例如kafka-eagle&#xff0c;并在其中创建docker-compose.yml文件&a…...

Java操作MongoDB

上一篇文章: http://blog.csdn.net/gaowenhui2008/article/details/40045719 介绍到了在MongoDB的控制台完成MongoDB的数据操作&#xff0c;通过前一篇文章我们对MongoDB有了全面的认识和理解。现在我们就用Java来操作MongoDB的数据。 开发环境&#xff1a; System&#xff1a…...

Java断言(assert)的介绍和使用

Java断言&#xff08;assert&#xff09;的介绍和使用 在Java编程中&#xff0c;断言&#xff08;assert&#xff09;是一种有用的工具&#xff0c;用于在代码中进行条件检查和调试。通过使用断言&#xff0c;我们可以验证程序的逻辑和假设&#xff0c;确保程序在运行时达到预…...

我的世界Fabric mod开发-快速漏斗

前往我的主页以阅读完整内容&#xff0c;并获取源码 DearXuan的主页 MOD介绍 使用漏斗链进行分类或传递物品时,常常会发现漏斗速度太慢,难以收集全部掉落物.或者漏斗太多,影响性能.而现有的漏斗加速mod则是引入新的快速漏斗,存在各种兼容问题.开服时发现paper服务器可以修改原…...

AI“应用商店”来了!OpenAI首批70个ChatGPT Plugin最全梳理

OpenAI放出大招&#xff0c;本周将向所有ChatGPT Plus用户开放联网功能和众多插件本周将向所有ChatGPT Plus用户开放联网功能和众多插件&#xff0c;允许ChatGPT访问互联网并使用70个第三方插件。 本批第三方插件能够全方位覆盖衣食住行、社交、工作以及学习等日常所需&#x…...

NSS LitCTF部分wp

web 1、PHP是世界上最好的语言&#xff01;&#xff01; 直接cat flag flagNSSCTF{11eaebe0-3764-410d-be83-b23532a24235} 2、这是什么&#xff1f;SQL &#xff01;注一下 &#xff01; 直接查询&#xff0c;发现注入点是id 使用sqlmap列出所以数据库 ​sqlmap -u "h…...

【开发者指南】如何在MyEclipse中编辑HTML或JSP文件?(一)

MyEclipse v2022.1.0正式版下载 如果您有HTML或JSP文件要编辑&#xff0c;这里将介绍如何编辑。查找以下信息&#xff1a; 编辑源代码大纲和属性视图参数页面 该功能在MyEclipse中是可用的。 一、HTML / JSP编辑器 要编辑HTML或JSP文件&#xff0c;请执行以下操作当中的一…...

关于博客停更的原因

进入我的主页浏览一下&#xff0c;就可以发现我写到linux就不写了&#xff0c;c后面页不写了&#xff0c;题解也不更新了&#xff0c;确实&#xff0c;我承认我懒惰了&#xff0c;我选择了向后学习&#xff0c;而不是总结&#xff0c;写博客是一个良好的习惯和面试官看到的能够…...

智能感知编码优化与落地实践

作者 | XHF 导读 基于人眼视觉特性出发的感知编码优化技术&#xff0c;成为互联网短视频、OTT 等 UGC 场景的重点优化手段&#xff0c;可以在降低视频码率的同时&#xff0c;提升视频的观看体验。 今天主要有 4 个方面的内容。首先给大家介绍一下感知编码的技术背景&#xff1b…...

OpenCL编程指南-5.1工作项函数-整数函数-公共函数

工作项函数 应用程序使用clEnqueueNDRangeKernel和 clEnqueueTask API将OpenCL中的数据并行和任务并行内核排队。对于一个数据并行内核&#xff08;使用clEnqueueNDRangeKernel排队等待执行)&#xff0c;应用程序会指定全局工作大小&#xff0c;即可以并行执行这个内核的工作项…...

教你接入Midjourney,不用梯子也能玩

1、效果 话不多说&#xff0c;先上最终出图效果&#xff0c; 我给的关键词是一只白色的猫 2、接入流程 API文档可以来这里查&#xff08;可以白嫖100次midjourney出图和10次gpt4体验&#xff09;&#xff0c;我这里精简一下接入流程&#xff0c;方便大家快速接入 2.1、文字生…...

Mysql中常用到的查询关键字

文章目录 1、join2、like 模糊查询3、or4、distinct5、in 包含6、group by 分组7、order by8、limit 1、join MySQL 的连接主要分为内连接和外连接。 什么是内连接&#xff1a; 取得两张表中满足存在连接匹配关系的记录。 什么是外连接&#xff1a; 不只取得两张表中满足存在…...

【ROS】ROS1工具详解

1、roscore 1.1 说明 运行roscore&#xff0c;将会启动三个功能&#xff1a;ROS Master主节点、ROS参数服务器和记录ROS日志输出节点 1.2 用法 roscore [可选参数]1.3 参数详解 -h, --help&#xff0c;帮助信息 -p PORT, --portPORT&#xff0c;指定端口号&#xff0c;默认…...

论Plant Simulation中的Init的使用及调用顺序

往期内容回顾: 一文搞懂Plant Simulation中的Rotation设置 Plant Simulation与python之Socket通信的数据交互问题 自主移动机器人模型制作 写在开头 在阅读之前,可以先尝试回答一下如下问题,如果都能答得上来,这篇文章就可以忽略不看了。 Q1:对于主模型中包括多…...

nginx实现正向代理

1.下载nginx nginx: download 选择自己需要的版版本下载下来 2.解压文件修改ngixn.conf配置文件 events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout…...

【spark】

实验5 Spark Structured Streaming编程实践 实验内容和要求 0.结构化流练习任务 0.1 讲义文件源-json数据任务。按照讲义中json数据的生成及分析&#xff0c;复现实验&#xff0c;并适当分析。 &#xff08;1&#xff09;创建程序生成JSON格式的File源测试数据 import osimp…...

ADO.NET 面试题

这里写自定义目录标题 什么是 ADO.NET&#xff1f;ADO.NET 的主要特点有哪些&#xff1f;ADO.NET 的四个组件分别是什么&#xff1f;什么是 Connection 串&#xff1f;Connection 的状态有哪些&#xff1f;什么是 DataAdapter&#xff1f;DataAdapter 的作用是什么&#xff1f;…...

第三篇、基于Arduino uno,用oled0.96寸屏幕显示dht11温湿度传感器的温度和湿度信息——结果导向

0、结果 说明&#xff1a;先来看看拍摄的显示结果&#xff0c;如果是你想要的&#xff0c;可以接着往下看。 1、外观 说明&#xff1a;本次使用的oled是0.96寸的&#xff0c;别的规格的屏幕不一定适用本教程&#xff0c;一般而言有显示白色、蓝色和蓝黄一起显示的&#xff0…...

什么是npu算力盒子,算力是越大越好吗?

一、什么是npu算力盒子&#xff1f;该怎么选&#xff1f; NPU&#xff08;神经处理单元&#xff09;算力盒子是一种专门用于进行人工智能计算的硬件设备&#xff0c;其中集成了高性能的NPU芯片。NPU是一种针对深度学习任务进行优化的处理器&#xff0c;具备高度并行计算和低功…...

季节主题作品展:LiuJuan20260223Zimage模型生成“春夏秋冬”四时美景

季节主题作品展&#xff1a;LiuJuan20260223Zimage模型生成“春夏秋冬”四时美景 最近在尝试用AI模型进行艺术创作&#xff0c;发现了一个挺有意思的模型——LiuJuan20260223Zimage。它特别擅长处理带有文化意境和自然主题的画面。为了测试它的能力&#xff0c;我决定让它挑战…...

【GUI-Agent】阶跃星辰 GUI-MCP 解读---()---执行层臀

起因是我想在搞一些操作windows进程的事情时&#xff0c;老是需要右键以管理员身份运行&#xff0c;感觉很麻烦。就研究了一下怎么提权&#xff0c;顺手瞄了一眼Windows下用户态权限分配&#xff0c;然后也是感谢《深入解析Windows操作系统》这本书给我偷令牌的灵感吧&#xff…...

ModbusRTU读取报文调试实战:用C#和Modbus Poll/Slave仿真器一步步抓包分析

ModbusRTU报文调试实战&#xff1a;从抓包分析到C#代码验证 当你第一次面对ModbusRTU协议时&#xff0c;那些十六进制数字组成的报文可能看起来像天书。但别担心&#xff0c;每个工业通信专家都曾经历过这个阶段。本文将带你用最直观的方式——抓包分析&#xff0c;来彻底理解M…...

SEU操作系统实践:从进程隐身到Shell构建的深度探索

1. 进程隐身&#xff1a;从原理到实战 第一次接触进程隐身这个概念时&#xff0c;我脑海中浮现的是科幻电影里的隐形战机。在Linux系统中&#xff0c;进程隐身同样神奇——它能让指定进程从系统监控工具中"消失"。这个实验不仅考验我们对进程管理的理解&#xff0c;…...

精准测试:AI代码变更分析如何缩短回归测试周期

&#x1f44b; 大家好&#xff0c;欢迎来到我的技术博客&#xff01; &#x1f4da; 在这里&#xff0c;我会分享学习笔记、实战经验与技术思考&#xff0c;力求用简单的方式讲清楚复杂的问题。 &#x1f3af; 本文将围绕人工智能这个话题展开&#xff0c;希望能为你带来一些启…...

RGThree-Comfy:彻底革新ComfyUI工作流管理的终极解决方案

RGThree-Comfy&#xff1a;彻底革新ComfyUI工作流管理的终极解决方案 【免费下载链接】rgthree-comfy Making ComfyUI more comfortable! 项目地址: https://gitcode.com/gh_mirrors/rg/rgthree-comfy 你是否曾经在ComfyUI中感到工作流管理变得混乱不堪&#xff1f;当节…...

Windows系统优化新选择:WinUtil一键式管理工具实用指南

Windows系统优化新选择&#xff1a;WinUtil一键式管理工具实用指南 【免费下载链接】winutil Chris Titus Techs Windows Utility - Install Programs, Tweaks, Fixes, and Updates 项目地址: https://gitcode.com/GitHub_Trending/wi/winutil 你是否曾为Windows系统的繁…...

你的Windows 11真的需要“减肥“吗?Win11Debloat一键解放30%系统资源

你的Windows 11真的需要"减肥"吗&#xff1f;Win11Debloat一键解放30%系统资源 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other chang…...

从零到一:在Axure中构建你的Quick UI设计系统

1. 为什么要在Axure中构建Quick UI设计系统 第一次接触Quick UI组件库时&#xff0c;你可能会有疑问&#xff1a;为什么非要把这套组件库整合进Axure&#xff1f;直接使用现成的UI工具不就好了吗&#xff1f;这个问题我也思考过很久&#xff0c;直到去年带队做一个跨部门协作的…...

基于AI+场景的数据安全管理平台建设方案:AI技术发展趋势与数据安全结合、AI+场景数据安全管理平台、AI+场景应用实践

该方案以AI技术为核心驱动力&#xff0c;围绕数据资产发现、事件分析、风险评估、策略处置等关键环节&#xff0c;构建了动态、智能的数据安全管理平台。通过自然语言处理、机器学习、深度学习、集成学习等技术&#xff0c;有效提升了敏感数据识别、异常行为检测、风险评估的准…...