算法打卡day25

今日任务:

1)491.递增子序列

2)46.全排列

3)47.全排列 II

491.递增子序列

题目链接:491. 非递减子序列 - 力扣(LeetCode)

给定一个整型数组, 你的任务是找到所有该数组的递增子序列,递增子序列的长度至少是2。
示例:
输入: [4, 6, 7, 7]
输出: [[4, 6], [4, 7], [4, 6, 7], [4, 6, 7, 7], [6, 7], [6, 7, 7], [7,7], [4,7,7]]

说明:
给定数组的长度不会超过15。
数组中的整数范围是 [-100,100]。
给定数组中可能包含重复数字,相等的数字应该被视为递增的一种情况

文章讲解:代码随想录 (programmercarl.com)

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

思路:

  1. 使用回溯算法,遍历数组中的每个元素。
  2. 对于当前元素,尝试将其加入当前子序列中,然后递归地向后探索更长的子序列。
  3. 在向后探索过程中,需要进行剪枝操作,以排除重复的结果和不满足递增条件的情况。
  4. 当遍历完所有可能的情况时,将满足要求的子序列加入结果列表中

 下面是一个错误代码

class Solution:def findSubsequences(self, nums: List[int]) -> List[List[int]]:self.result = []self.backtrack(nums, 0, [])return self.resultdef backtrack(self, nums, start, path):# 如果当前路径长度大于1,则将该路径加入结果列表中if len(path) > 1:self.result.append(path[:])# 遍历数组中从start索引开始的所有元素for i in range(start, len(nums)):# 剪枝条件1:如果当前元素与前面的元素相同,则跳过,避免重复结果if i > start and nums[i] in nums[:i]:continue# 剪枝条件2:如果当前元素小于路径中的最后一个元素,跳过,确保生成的子序列是递增的if not path or nums[i] >= path[-1]:# 递归path.append(nums[i])self.backtrack(nums, i + 1, path)path.pop()

在第一个剪枝部分,不能直接去用当前nums[i]与数组之前的部分判断重复,这样是判断当前元素是否出现在路径中
这样导致的我们找的子集是没有重复元素的,但[1,2,1,1]这种是符合要求的,所以这样剪枝是错的
而是应该判断当前层,元素nums[i]是否遍历过 

46.全排列

题目链接:46. 全排列 - 力扣(LeetCode)

给定一个 没有重复 数字的序列,返回其所有可能的全排列。

示例:
输入: [1,2,3]
输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1] ]

文章讲解:代码随想录 (programmercarl.com)

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

思路:

使用回溯算法来生成全排列。
维护一个结果列表 result 来存储所有可能的全排列。
回溯函数 backtrack 的参数包括当前要排列的数组 nums 和当前已生成的部分排列 path。
在回溯函数中,首先判断是否满足终止条件,即 path 的长度是否等于 nums 的长度,如果满足则将 path 加入 result 中。
然后遍历数组 nums 中的每个元素,如果该元素已经在 path 中,则跳过,否则将其加入 path 中,递归调用回溯函数,完成后需要撤销选择,以便尝试其他未选择的元素。

class Solution:def permute(self, nums: List[int]) -> List[List[int]]:self.result = []self.backtrack(nums, [])return self.resultdef backtrack(self, nums, path):# 当遍历完时,path长度等于原数组长度if len(path) == len(nums):self.result.append(path[:])for i in range(len(nums)):# 剪枝:如果当前元素已经遍历则跳过if nums[i] in path:continue# 递归层path.append(nums[i])self.backtrack(nums, path)path.pop()

感想:

这题比较简单,递归遍历时,起始位置与之前的不一样,这次从头遍历

47.全排列 II

题目链接:47. 全排列 II - 力扣(LeetCode)

给定一个可包含重复数字的序列 nums ,按任意顺序 返回所有不重复的全排列。

示例 1:
输入:nums = [1,1,2]
输出: [[1,1,2], [1,2,1], [2,1,1]]

示例 2:
输入:nums = [1,2,3]
输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

提示:
1 <= nums.length <= 8
-10 <= nums[i] <= 10

文章讲解:代码随想录 (programmercarl.com)

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

思路:

1)使用回溯算法来生成全排列。
2)首先对原数组进行排序,这样重复元素会相邻,方便后续剪枝操作。
3)回溯函数 backtrack 的参数包括当前要排列的数组 nums、当前已生成的部分排列 path 和一个数组 used,用于记录每个数字是否已被使用。
4)在回溯函数中,首先判断是否满足终止条件,即 path 的长度是否等于 nums 的长度,如果满足则将 path 加入 result 中。
5)然后遍历数组 nums 中的每个元素,如果该元素已经被使用过,则跳过,否则标记该元素为已使用,选择当前元素并递归调用回溯函数,完成后需要撤销选择,并将当前元素标记为未使用,以便尝试其他未选择的元素。

class Solution:def permuteUnique(self, nums: List[int]) -> List[List[int]]:nums.sort()self.result = []self.backtrack(nums, [], [False] * len(nums))return self.resultdef backtrack(self, nums, path,used):# 终止条件:当路径长度等于原数组长度时,表示已经生成了一个全排列if len(path) == len(nums):self.result.append(path[:])for i in range(len(nums)):# 剪枝:如果当前元素已经遍历则跳过if used[i]:continue# 剪枝:同一层不能重复取相同的数字,若前一个相同数字未被使用,则跳过当前数字if i > 0 and nums[i] == nums[i - 1] and used[i-1] == False:continueused[i] = True # 标记当前元素已被使用# 递归层path.append(nums[i])self.backtrack(nums, path,used)path.pop()used[i] = False

感想:

这一题有两个剪枝,第一个是每一个树层上,也就是同一级的for循环上,如果有重复的,我们就不用继续了,因为第一个元素出现时就已经涵盖所有可能性。我们可以对数组排序,然后比较当前nums[i]是否等于前一个,还需要补充的限制是,前一个已经遍历过了
第二个剪枝就是与上一题一样的,每一个树枝上已经使用的放进path中的就跳过

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/791184.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

composure合成透明通道

composure合成透明通道 2022-05-23 08:59 [技巧分享]使用配有HDRI的背板的进行合成 Using Composure with a Bac - 1.Using Composure with a Backplate and H.mp41启用插件2线性色彩空间3打开合成面板4面板新建合成新建三个图层 FG前面物体&#xff0c;背景物体 去掉阴影 flo…

Zabbix6 - Web管理网络拓扑/端口流量监控配置手册

Zabbix6 - Web管理网络拓扑/端口流量监控配置手册 概述: 1)Zabbix能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。 Zabbix由两部分构成,Zabbix Server与可选组件Zabbix Agent。通过C/S模式采集数据,通过B…

60道Java经典面试题总结

1、Spring 有几种配置方式&#xff1f; 1、xml 配置文件 <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/beans"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:…

量化交易入门(四十一)ASI指标Python实现和回测

老规矩先上图&#xff0c;看看ASI指标使用苹果数据回测后的结果如何。 一、策略运行结果 执行的结果&#xff1a; Starting Portfolio Value: 100000.00 Final Portfolio Value: 92514.82 Annualized Return: -1.93% Sharpe Ratio: -0.27 Max Drawdown: 25.34% Max Drawdown …

【教学类-09-04】20240401细线迷宫图03(A4横版一页-4份横版)

作品展示&#xff1a; 背景需求&#xff1a; 【教学类-09-02】20240331细线迷宫图01&#xff08;A4横版一页1份横版&#xff09;-CSDN博客文章浏览阅读779次&#xff0c;点赞28次&#xff0c;收藏6次。【教学类-09-02】20240331细线迷宫图01&#xff08;A4横版一页1份横版&…

机器学习周记(第三十二周:文献阅读-时空双通路框架)2024.3.25~2024.3.31

目录 摘要 ABSTRACT 1 论文信息 1.1 论文标题 1.2 论文摘要 1.3 论文模型 1.3.1 Spatial Encoder&#xff08;空间编码器&#xff09; 1.3.2 Temporal Encoder&#xff08;时间编码器&#xff09; 2 相关代码 摘要 本周阅读了一篇运用GNN进行时间序列预测的论文。论文…

【数据处理包Pandas】分组及相关操作

目录 一、初步认识分组并查看分组信息&#xff08;一&#xff09;通过聚合函数查看分组信息&#xff08;二&#xff09;转换成列表查看所有组的信息&#xff08;三&#xff09;通过循环查看各组的名称和组中的数据信息&#xff08;四&#xff09;通过get_group()方法直接获得一…

【蓝桥杯练习】tarjan算法求解LCA

还是一道比较明显的求LCA(最近公共祖先)模型的题目,我们可以使用多种方法来解决该问题&#xff0c;这里我们使用更好写的离线的tarjan算法来解决该问题。 除去tarjan算法必用的基础数组&#xff0c;我们还有一个数组d[],d[i]记录的是每个点的出度&#xff0c;也就是它的延迟时间…

高级IO/多路转接-select/poll(1)

概念背景 IO的本质就是输入输出 刚开始学网络的时候&#xff0c;我们简单的写过一些网络服务&#xff0c;其中用到了read&#xff0c;write这样的接口&#xff0c;当时我们用的就是基础IO&#xff0c;高级IO主要就是效率问题。 我们在应用层调用read&&write的时候&…

YOLOv2

YOLOv2 论文介绍论文改进1. Batch Normalization2. High Resolution Classifier3. Convolutional With Anchor Boxes4. vgg16换成darknet-195. Dimension Clusters&#xff08;w h的聚类&#xff09;6 预测坐标7. passthrough8. 多尺度输入训练 损失函数 论文介绍 论文名字&am…

Educational Codeforces Round 133 (Rated for Div. 2) C. Robot in a Hallway

题目 思路&#xff1a; #include <bits/stdc.h> using namespace std; #define int long long #define pb push_back #define fi first #define se second #define lson p << 1 #define rson p << 1 | 1 const int maxn 1e6 5, inf 1e18, maxm 4e4 5; c…

多模态系列-综述Video Understanding with Large Language Models: A Survey

本文是LLM系列文章,针对《Video Understanding with Large Language Models: A Survey》的翻译。 论文链接:https://arxiv.org/pdf/2312.17432v2.pdf 代码链接:https://github.com/yunlong10/Awesome-LLMs-for-Video-Understanding 大型语言模型下的视频理解研究综述 摘要…

人工智能大模型+智能算力,企商在线以新质生产力赋能数字化转型

2024 年3月28 日&#xff0c;由中国互联网协会主办、中国信通院泰尔终端实验室特别支持的 2024 高质量数字化转型创新发展大会暨铸基计划年度会议在京召开。作为新质生产力代表性企业、数算融合领导企业&#xff0c;企商在线受邀出席大会主论坛圆桌对话&#xff0c;与行业专家共…

Lora人机界面开发 3

1 显示原理 液晶的形成&#xff1a;像水一样液晶介于固态和液态之间 偏光原理&#xff1a;两块偏光的栅栏角度相互垂直时光线就完全无法通过 内部结构&#xff1a;利用电场控制液晶分支的旋转 颜色深度 TFT开关的工作原理&#xff1a; 扫描线连接同一列所有TFT栅极电极&…

通过mapreduce程序统计旅游订单(wordcount升级版)

通过mapreduce程序统计旅游订单&#xff08;wordcount升级版&#xff09; 本文将结合一个实际的MapReduce程序案例&#xff0c;探讨如何通过分析旅游产品的预订数据来揭示消费者的偏好。 程序概览 首先&#xff0c;让我们来看一下这个MapReduce程序的核心代码。这个程序的目…

创新视角:探索系统产品可用性测试的前沿分类方法与实践应用

一、可用性测试概念 1、什么是可用性&#xff1f; 任何与人可以发生交互的产品都应该是可用的&#xff0c;就一般产品而言&#xff0c;可用性被定义为目标用户可以轻松使用产品来实现特定目标。 ISO9241/11中的定义是&#xff1a; 一个产品可以被特定的用户在特定的场景中&a…

跨越时空,启迪智慧:奇趣相机重塑儿童摄影与教育体验

【科技观察】近期&#xff0c;奇趣未来公司以其创新之作——“奇趣相机”微信小程序&#xff0c;强势进军儿童AI摄影市场。这款专为亚洲儿童量身定制的应用&#xff0c;凭借精准贴合亚洲儿童面部特征的AIGC大模型&#xff0c;以及丰富的摄影模板与场景设定&#xff0c;正在重新…

Ps:匹配颜色

匹配颜色 Match Color命令可以将一个图像的颜色与另一个图像的颜色相匹配。 Ps菜单&#xff1a;图像/调整/匹配颜色 Adjustments/Match Color 匹配颜色命令可匹配多个图像之间、多个图层之间或者多个选区之间的颜色&#xff0c;还可以通过更改亮度和色彩范围以及中和色痕来调整…

Day17-【Java SE进阶】特殊文本文件、日志技术

一、特殊文本文件 为什么要用这些特殊文件&#xff1f; 存储多个用户的&#xff1a;用户名、密码 存储有关系的数据&#xff0c;做为系统的配置文件做为信息进行传输 日志技术 把程序运行的信息&#xff0c;记录到文件中&#xff0c;方便程序员定位bug、并了解程序的执行情…

Java并发编程基础面试题详细总结

1. 什么是线程和进程? 1.1 何为进程? 进程是程序的一次执行过程&#xff0c;是系统运行程序的基本单位&#xff0c;因此进程是动态的。系统运行一个程序即是一个进程从创建&#xff0c;运行到消亡的过程。 在 Java 中&#xff0c;当我们启动 main 函数时其实就是启动了一个…