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

491.递增子序列

未去重的代码

class Solution:def findSubsequences(self, nums: List[int]) -> List[List[int]]:result = []self.backtracking(nums, result, [], 0)return resultdef backtracking(self, nums, result, path, startIndex):if len(path) >= 2:result.append(path[:])for i in range(startIndex, len(nums)):if len(path) >= 1 and nums[i] < path[-1]:continuepath.append(nums[i])self.backtracking(nums, result, path, i+1)path.pop()

本题是树结构的同一层剪枝

但是本题不能排序,和之前的剪枝差别很大

class Solution:def findSubsequences(self, nums: List[int]) -> List[List[int]]:result = []self.backtracking(nums, result, [], 0)return resultdef backtracking(self, nums, result, path, startIndex):if len(path) >= 2:result.append(path[:])used = set()for i in range(startIndex, len(nums)):if len(path) >= 1 and nums[i] < path[-1]:continueif nums[i] in used:continueused.add(nums[i])path.append(nums[i])self.backtracking(nums, result, path, i+1)path.pop()

优化点:因为给定的数字范围是-100 <= nums[i] <= 100,因此set可以优化为数组

46.全排列

class Solution:def permute(self, nums: List[int]) -> List[List[int]]:result = []used = [False] * len(nums)self.backtracking(nums, result, [], used)return resultdef backtracking(self, nums, result, path, used):if len(path) == len(nums):result.append(path[:])returnfor i in range(len(nums)):if used[i]:continuepath.append(nums[i])used[i] = Trueself.backtracking(nums, result, path, used)path.pop()used[i] = False

47.全排列 II

去重的思路需要继续理解

class Solution:def permuteUnique(self, nums: List[int]) -> List[List[int]]:result = []used = [False] * len(nums)nums.sort()self.backtracking(nums, result, [], used)return resultdef backtracking(self, nums, result, path, used):if len(path) == len(nums):result.append(path[:])returnfor i in range(len(nums)):if used[i]:continueif i > 0 and nums[i] == nums[i-1] and not used[i-1]:continuepath.append(nums[i])used[i] = Trueself.backtracking(nums, result, path, used)path.pop()used[i] = False

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

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

相关文章

【代码随想录】【算法训练营】【第20天】 [654]最大二叉树 [617]合并二叉树 [700]二叉搜索树中的搜索 [98]验证二叉搜索树

前言 思路及算法思维&#xff0c;指路 代码随想录。 题目来自 LeetCode。 day 19&#xff0c;一个愉快的周日~ day 20&#xff0c;一个悲伤的周一~ 题目详情 [654] 最大二叉树 题目描述 654 最大二叉树 解题思路 前提&#xff1a;构造二叉树 思路&#xff1a;寻找根节…

python两个列表如何取交集

在Python编程中&#xff0c;我们经常需要处理各种数据集合&#xff0c;包括列表&#xff08;list&#xff09;。有时候&#xff0c;我们可能想要找出两个列表中的共同元素&#xff0c;这通常被称为取交集。下面&#xff0c;我将介绍几种在Python中实现两个列表取交集的方法。 …

如何设置XHSC(华大)单片机的IO口中断

XHSC(华大)单片机IO口中断使用 一、代码说明 华大单片机的历程在华大或者小华的官网上都可以下载到,但是我们下载的历程基本注释都是非常简单,有的还没有注释;再加上小华跟华大的历程在代码架构上有所区别,所以新手在直接调用华大或者小华历程后,历程代码的可读性并不…

内网安全--域渗透准备知识

目录 知识点&#xff1a; 0x01 0x02 0x03 系列点&#xff1a; Linux主机信息收集 windows主机信息收集 知识点&#xff1a; 0、域产生原因 1、内网域的区别 2、如何判断在域内 3、域内常见信息收集 4、域内自动化工具收集 -局域网&工作组&域环境区别 -域…

Hinton揭秘GPT之父【Ilya】成长历程:Scaling Law是他学生时代就有的直觉

2003年夏天的一个周日&#xff0c;AI教父Hinton在多伦多大学的办公室里敲代码&#xff0c;突然响起略显莽撞的敲门声。门外站着一位年轻的学生&#xff0c;说自己整个夏天都在打工炸薯条&#xff0c;但更希望能加入Hinton的实验室工作。Hinton问&#xff0c;你咋不预约呢&#…

SQLite 如何导出某些SQLite3表的数据

https://deepinout.com/sqlite/sqlite-questions/44_sqlite_how_do_i_dump_the_data_of_some_sqlite3_tables.html 要导出整个SQLite3数据库的数据&#xff0c;可以使用SQLite3的.dump命令。首先&#xff0c;打开终端或命令提示符&#xff0c;并进入SQLite3终端会话。然后&…

# LLM高效微调详解-从Adpter、PrefixTuning到LoRA

一、背景 目前NLP主流范式是在大量通用数据上进行预训练语言模型训练&#xff0c;然后再针对特定下游任务进行微调&#xff0c;达到领域适应&#xff08;迁移学习&#xff09;的目的。 Context Learning v.s. SFT 指令微调是预训练语言模型微调的主流范式&#xff0c;其目的是…

嵌入式C语言--基础知识

嵌入式C语言–基础知识 嵌入式C语言--基础知识 嵌入式C语言--基础知识一. 含参数的宏与函数的不同点1&#xff09;函数2&#xff09;宏 二. scanf格式化输入的注意事项三. 指针1&#xff09;指针变量(地址变量&#xff09;2&#xff09;指针常见含义 四. 数组五. 数组与指针的区…

解读 Nginx:构建高效反向代理和负载均衡的秘密

解读 Nginx&#xff1a;构建高效反向代理和负载均衡的秘密 一、简介 Nginx (Engine-X) 是一个高性能的 HTTP 和反向代理服务器&#xff0c;也是一个 IMAP/POP3/SMTP 代理服务器。Nginx 以其高并发、高可靠性、低内存消耗等特点&#xff0c;成为了众多互联网公司首选的服务器软…

通用代码生成器应用场景三,遗留项目反向工程

通用代码生成器应用场景三&#xff0c;遗留项目反向工程 如果您有一个遗留项目&#xff0c;要重新开发&#xff0c;或者源代码遗失&#xff0c;或者需要重新开发&#xff0c;但是希望复用原来的数据&#xff0c;并加快开发。 如果您的项目是通用代码生成器生成的&#xff0c;…

在智慧城市建设中,大数据发挥着怎样的关键作用?

在智慧城市建设中&#xff0c;大数据发挥着以下关键作用&#xff1a; 数据采集与监测&#xff1a;大数据技术能够帮助城市采集和监测各种数据&#xff0c;包括气象、环境、交通、能源等方面的数据。这些数据可以用来分析和预测城市的运行情况&#xff0c;并为城市的各个部门提供…

阿里云产品DTU评测报告(二)

阿里云产品DTU评测报告&#xff08;二&#xff09; 问题回顾问题处理继续执行 问题回顾 基于上一次DTU评测&#xff0c;在评测过程中遇到了windows系统情况下执行amp命令失败的情况&#xff0c;失败情况如图 导致后续命令无法执行&#xff0c;一时之间不知如何处理&#xff0…

20 道大模型面试问题(含答案)

大型语言模型在生成式人工智能&#xff08;GenAI&#xff09;和人工智能&#xff08;AI&#xff09;中正变得越来越有价值。这些复杂的算法增强了人类的能力&#xff0c;并在各个领域促进了效率和创造力。 节前&#xff0c;我们组织了一场算法岗技术&面试讨论会&#xff0…

python 两个表格字段列名称值,对比字段差异

支持xlsx,xls文件&#xff0c;相互对比字段列 输出两个表格文件相同字段&#xff0c;置底色为绿色 存在差异的不同字段&#xff0c;输出两个新的表格文件&#xff0c;差异字段&#xff0c;置底色为红色 注意点&#xff1a;读取的文件仅支持xlsx格式&#xff0c;头列需要删除…

【AD21】Gerber文件的输出

Gerber文件是对接生产的文件&#xff0c;该文件包含了PCB的所有层的信息&#xff0c;如铜层、焊盘、丝印层、阻焊层等。板厂使用这些文件来准备生产工艺。虽然可以将PCB发给板厂去打板&#xff0c;但是对于公司而言&#xff0c;直接发PCB会有泄密风险&#xff0c;Gerber文件会相…

《宝贵的人生建议》

致读者 2024/05/25 发表想法 简练表达&#xff0c;发散&#xff08;灵活&#xff09;运用。 原文&#xff1a;在写作过程中&#xff0c;我的主要精力是用在这个方面&#xff1a;把这些重要的经验教训浓缩为尽可能紧凑简炼、易于传播的语言。我鼓励读者在阅读时扩展这些“种子”…

不能错过的AI知识学习神器「Mo卡片」

1. 「Mo卡片」——知识点的另一种承载方式 1.1 产品特点 &#x1f4f1;一款专为渴望理解和掌握人工智能知识的小伙伴量身打造的轻量级 App。 &#x1f3f7;AI 知识卡片集 Mo卡片内置了 26 套卡片集&#xff0c;总计 1387 张卡片&#xff0c;每张卡片都能获得 1 个核心知识。…

GpuMall智算云:AUTOMATIC1111/stable-diffusion-webui/stable-diffusion-webui-v1.8.0

配置环境介绍 目前平台集成了 Stable Diffusion WebUI 的官方镜像&#xff0c;该镜像中整合如下资源&#xff1a; GpuMall智算云 | 省钱、好用、弹性。租GPU就上GpuMall,面向AI开发者的GPU云平台 Stable Diffusion WebUI版本&#xff1a;v1.8.0 Python版本&#xff1a;3.10.…

nginx与nginx-rtmp-module安装

nginx与nginx-rtmp-module安装 画了好几天图&#xff0c;实在有些乏力&#xff0c;找点有意思的事情做做 觉得视频流传输挺有意思&#xff0c;B站找了些视频&#xff0c;但感觉有些大同小异&#xff0c;讲得不是很清楚 FFmpeg/RTMP/webRTC丨90分钟搞定直播逻辑-推流-流媒体服…