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

day31-数据结构力扣

1049. 最后一块石头的重量 II题目链接1049. 最后一块石头的重量 II - 力扣LeetCode思路1.dp 含义dp[i][j]前 i 块石头容量 j最大可装重量2.递推公式max(不选选)对于第 i 块石头有两种选择不选或选不选第 i 块石头dp[i][j] dp[i-1][j]选第 i 块石头前提石头重量 ≤ 当前容量 jdp[i][j] dp[i-1][j - stones[i-1]] stones[i-1]3.初始化第一行、第一列全为 0dp[0][j] 00 块石头任何容量都装不了最大重量为 0dp[i][0] 0容量为 0任何石头都装不了最大重量为 04.遍历外层石头内层容量5.推导最后取dp[n][target]计算sum - 2*dp提交class Solution: def lastStoneWeightII(self, stones: List[int]) - int: total sum(stones) target total // 2 n len(stones) # 1. dp[i][j]前i个石头容量j最大重量 dp [[0] * (target 1) for _ in range(n 1)] # 4. 遍历顺序先石头后容量 for i in range(1, n 1): w stones[i - 1] for j in range(1, target 1): if j w: # 装不下只能不选 dp[i][j] dp[i - 1][j] else: # 2. 递推公式选/不选 取最大 dp[i][j] max(dp[i - 1][j], dp[i - 1][j - w] w) # 结果 return total - 2 * dp[n][target]494. 目标和题目链接494. 目标和 - 力扣LeetCode思路1.dp 含义dp[i][j]前 i 个数和为 j 的表达式数目2.递推公式dp[i][j] 加num 减num对第 i 个数不选dp[i][j] dp[i-1][j]选dp[i][j] dp[i-1][j - nums[i-1]]最终递推公式dp[i][j] dp[i-1][j] dp[i-1][j - nums[i-1]]3.初始化dp[0][0] 1dp[0][0] 10 个数字和为 0 的表达式只有1 种什么都不选其余dp[0][j] 0无法凑出非 0 和4.遍历外层数字内层所有可能和5.推导最后取dp[n][target]即为答案提交class Solution: def findTargetSumWays(self, nums: List[int], target: int) - int: total sum(nums) # 无法构成的情况 if (total target) % 2 ! 0: return 0 if abs(target) total: return 0 x (total target) // 2 n len(nums) # 1. dp[i][j]前i个数和为j的方案数 dp [[0] * (x 1) for _ in range(n 1)] # 3. 初始化 dp[0][0] 1 # 4. 遍历顺序 for i in range(1, n 1): num nums[i-1] for j in range(0, x 1): # 2. 递推公式 dp[i][j] dp[i-1][j] if j num: dp[i][j] dp[i-1][j - num] return dp[n][x]474.一和零题目链接474. 一和零 - 力扣LeetCode思路1.dp 含义dp[i][j] i 个 0、j 个 1 的最大子集长度2.递推公式max(不选, 选1)对每个字符串含 zero 个 0one 个 1不选dp[i][j] 原来的值选dp[i - zero][j - one] 1递推公式dp[i][j] max( dp[i][j], dp[i - zero][j - one] 1 )3.初始化全 0全部初始化为00 个 0、0 个 1 时最多选 0 个字符串没有物品时任何容量都是 04.遍历先字符串再倒序遍历 0、1 数量倒序遍历 01 背包标准做法防止重复选取5.结果dp[m][n]提交class Solution: def findMaxForm(self, strs: List[str], m: int, n: int) - int: # 初始化dpi个0j个1最大子集长度 dp [[0] * (n 1) for _ in range(m 1)] # 遍历每个字符串物品 for s in strs: # 统计当前字符串的0和1数量 zero s.count(0) one s.count(1) # 二维01背包必须倒序遍历 for i in range(m, zero - 1, -1): for j in range(n, one - 1, -1): # 递推公式 dp[i][j] max(dp[i][j], dp[i - zero][j - one] 1) return dp[m][n]

相关文章:

day31-数据结构力扣

1049. 最后一块石头的重量 II 题目链接1049. 最后一块石头的重量 II - 力扣(LeetCode) 思路 1.dp 含义:dp[i][j] 前 i 块石头,容量 j,最大可装重量 2.递推公式:max(不选,选) 对于第 i 块石…...

数据分析学习01(黑马)-Linux基础

一.操作系统概述 计算机分类 计算机一般分为个人计算机(笔记、台式机)与 企业级服务器(1U、2U、机柜、塔式、刀片)两种形式。 计算机组成 标题 计算机资源分为2 部分:硬件资源、软件资源 硬件资源:所谓的硬…...

3分钟掌握Alice-Tools:游戏资源编辑与提取的终极解决方案

3分钟掌握Alice-Tools:游戏资源编辑与提取的终极解决方案 【免费下载链接】alice-tools Tools for extracting/editing files from AliceSoft games. 项目地址: https://gitcode.com/gh_mirrors/al/alice-tools 你是否曾梦想过能够轻松修改自己喜爱的AliceSo…...

如何深度解析特斯拉Model 3/Y CAN总线协议:实战应用完全指南

如何深度解析特斯拉Model 3/Y CAN总线协议:实战应用完全指南 【免费下载链接】model3dbc DBC file for Tesla Model 3 CAN messages 项目地址: https://gitcode.com/gh_mirrors/mo/model3dbc 特斯拉Model 3和Model Y的CAN总线协议解析是汽车电子开发和物联网…...

2026 最新 Python+AI 从零搭建人工智能项目全攻略

📝 本章学习目标:本教程专为 2026 年零基础学习者打造,从 Python 基础语法入手,系统覆盖 AI 核心工具库、机器学习、大模型应用开发,最终带你从零搭建完整 AI 项目。全程无晦涩数学、无前置要求,纯代码实战…...

SMS Backup+技术评测:如何安全高效地备份安卓通信数据

SMS Backup技术评测:如何安全高效地备份安卓通信数据 【免费下载链接】sms-backup-plus Backup Android SMS, MMS and call log to Gmail / Gcal / IMAP 项目地址: https://gitcode.com/gh_mirrors/sms/sms-backup-plus 你是否曾因手机丢失、系统重置或设备更…...

如何打破网络限制?3大核心能力构建您的专属离线学习图书馆

如何打破网络限制?3大核心能力构建您的专属离线学习图书馆 【免费下载链接】MoocDownloader An MOOC downloader implemented by .NET. 一枚由 .NET 实现的 MOOC 下载器. 项目地址: https://gitcode.com/gh_mirrors/mo/MoocDownloader 想象一下,您…...

基于大语言模型的AI智能体开发:从模块化架构到实践指南

1. 项目概述:从个人助手到开源协作的JARVIS如果你对AI和自动化感兴趣,最近在GitHub上逛,大概率会看到一个名字:Likhithsai2580/JARVIS。这可不是漫威电影里那个无所不能的钢铁侠AI管家,而是一个实实在在的开源项目。但…...

Vienna整流器核心器件选型实战:从理论计算到工程实现

1. Vienna整流器设计入门:从理论到实践的跨越 第一次接触Vienna整流器设计时,我被这个看似简单的电路难住了。理论计算明明很完美,实际搭建时却总是遇到各种问题。后来才发现,器件选型才是真正考验工程师功力的地方。今天我就以1.…...

研华PCI-1285运动控制卡C#开发避坑指南:从API封装到异常处理

研华PCI-1285运动控制卡C#开发避坑指南:从API封装到异常处理 在工业自动化领域,运动控制卡的稳定性和可靠性直接关系到生产效率和设备安全。研华PCI-1285作为一款高性能运动控制卡,其C#开发过程中存在诸多技术细节需要特别注意。本文将深入剖…...

Python数据清洗实战:5个高效函数解决常见问题

1. 数据清洗:从入门到精通的5个Python实用函数作为一名长期与数据打交道的从业者,我深知数据清洗这个"脏活累活"的重要性。无论你是刚入门的数据分析师,还是经验丰富的数据科学家,数据清洗都占据了日常工作70%以上的时间…...

Virtuoso ADE脚本进阶:一键参数化扫描并绘制gmid设计曲线簇(含OCEAN脚本修改指南)

Virtuoso ADE脚本进阶:一键参数化扫描并绘制gmid设计曲线簇(含OCEAN脚本修改指南) 在模拟电路设计中,gmid(gm/Id)方法已经成为现代CMOS设计的重要工具。这种方法通过将晶体管的跨导gm与漏电流Id的比值作为核…...

杭电网安复试C语言上机题保姆级攻略:从猴子吃桃到希尔排序,手把手带你搞定

杭电网安复试C语言上机题实战指南:从解题思维到考场策略 去年此时,我和屏幕前的你一样,面对杭电网安复试的上机环节既期待又忐忑。记得第一次看到"猴子吃桃"题目时,那种无从下手的迷茫感至今记忆犹新。但经过系统准备后…...

终极指南:如何使用applera1n免费绕过iOS设备激活锁

终极指南:如何使用applera1n免费绕过iOS设备激活锁 【免费下载链接】applera1n icloud bypass for ios 15-16 项目地址: https://gitcode.com/gh_mirrors/ap/applera1n applera1n是一款专为iOS 15-16.6.1系统设计的免费激活锁绕过工具,基于著名的…...

VSCode低代码调试实战手册(2024最新版):覆盖Power Apps/Logic Apps/Canvas App的断点穿透与变量热观测技术

更多请点击: https://intelliparadigm.com 第一章:VSCode低代码调试的核心价值与演进脉络 在现代开发范式中,VSCode 已超越传统编辑器角色,成为低代码/无代码平台与专业开发深度协同的关键枢纽。其核心价值在于将可视化逻辑编排与…...

RV1126开发板调试IMX214摄像头:从I2C不通到抓取RAW图的完整排坑实录

RV1126开发板调试IMX214摄像头:从I2C不通到抓取RAW图的完整排坑实录 当Owl开发板遇上IMX214传感器,本以为按照官方文档添加驱动就能轻松搞定,没想到迎接我的却是一连串的硬件玄学和软件陷阱。如果你也正在RV1126平台上调试新Sensor&#xff0…...

Windows 10上Hadoop 3.3.6环境搭建避坑全记录:从winutils到IDEA Maven项目实战

Windows 10上Hadoop 3.3.6环境搭建避坑全记录:从winutils到IDEA Maven项目实战 在Windows系统上搭建Hadoop开发环境,对于想要学习大数据技术却又没有Linux服务器的开发者来说,是一个极具实用价值的技能。不同于Linux环境下的"一键式&quo…...

上市公司-绿色新闻、环保新闻数据库(2007-2023年)

01、数据介绍上市公司绿色新闻报道的内容确实涵盖了多个关键方面,旨在向投资者、消费者、监管机构及广大公众传达企业在环境保护、可持续发展和社会责任方面的实践与成效。上市公司绿色新闻报道不仅是企业向外界传递其绿色发展成果和承诺的窗口,也是促进…...

如何用PX4神经网络控制技术彻底革新你的无人机飞行体验

如何用PX4神经网络控制技术彻底革新你的无人机飞行体验 【免费下载链接】PX4-Autopilot PX4 Autopilot Software 项目地址: https://gitcode.com/gh_mirrors/px/PX4-Autopilot 你是否曾为无人机在复杂环境中的控制问题而烦恼?当传统PID控制器面对动态风场、负…...

如何快速掌握火灾模拟:Fire Dynamics Simulator 完全指南

如何快速掌握火灾模拟:Fire Dynamics Simulator 完全指南 【免费下载链接】fds Fire Dynamics Simulator 项目地址: https://gitcode.com/gh_mirrors/fd/fds Fire Dynamics Simulator(FDS)是由美国国家标准与技术研究院(NI…...

打造专属方块世界:PCL启动器全方位配置与优化指南

打造专属方块世界:PCL启动器全方位配置与优化指南 【免费下载链接】PCL Minecraft 启动器 Plain Craft Launcher(PCL)。 项目地址: https://gitcode.com/gh_mirrors/pc/PCL Plain Craft Launcher(简称PCL)是一款…...

嵌入式C如何扛住300KB模型推理负载?:ARM Cortex-M7上量化+算子裁剪实战全链路拆解

更多请点击: https://intelliparadigm.com 第一章:嵌入式C与轻量级大模型适配的底层挑战全景 在资源受限的MCU(如ARM Cortex-M4/M7、ESP32)上部署轻量级大模型(如TinyLlama、Phi-3-mini、Qwen2-0.5B量化版&#xff0…...

告别“白板”DSP:手把手教你用Visual DSP++ 5.1.2为BF533目标板克隆固件(从仿真器连接到HEX文件保存)

嵌入式工程师必备:Visual DSP 5.1.2固件克隆全流程实战指南 在嵌入式系统维护和小批量生产中,经常会遇到需要从已编程的DSP芯片中提取固件的情况。无论是为了维修替换、版本归档还是生产测试,掌握可靠的固件克隆技术都至关重要。本文将手把手…...

HNU-计算机系统-实验三:逆向拆弹实战——从汇编迷雾到通关密钥

1. 逆向拆弹初体验:当代码侦探的第一天 第一次打开bomb可执行文件时,那种感觉就像拿到一个密封的黑匣子。终端里冷冰冰的"Welcome to my fiendish little bomb..."提示语,配合着闪烁的光标,简直就是在挑衅。我记得当时盯…...

MATLAB等高线图进阶:从基础绘制到高级定制化

1. 等高线图基础绘制与核心参数解析 第一次接触MATLAB等高线图时,我被它展现三维数据的能力惊艳到了。记得当时处理一组地质勘探数据,需要可视化地下矿藏分布,contour函数只用三行代码就解决了问题: [X,Y] meshgrid(-3:0.1:3); Z…...

Free Texture Packer完全指南:颠覆性精灵表制作工具的革命性应用

Free Texture Packer完全指南:颠覆性精灵表制作工具的革命性应用 【免费下载链接】free-tex-packer Free texture packer 项目地址: https://gitcode.com/gh_mirrors/fr/free-tex-packer 你是否曾在游戏开发中被数百个零散图片拖慢加载速度而苦恼&#xff1f…...

从智能音箱到车载语音:拆解非线性回声消除(AEC)在IoT设备里的实战与选型

从智能音箱到车载语音:非线性回声消除(AEC)在IoT设备中的工程实践 当你在智能音箱前喊出"播放周杰伦的歌"时,设备需要在0.5秒内完成声学回声消除、语音唤醒和指令识别这一系列复杂操作。而在时速80公里的汽车里&#xf…...

如何快速实现MASA模组界面本地化:终极中文汉化实战指南

如何快速实现MASA模组界面本地化:终极中文汉化实战指南 【免费下载链接】masa-mods-chinese 一个masa mods的汉化资源包 项目地址: https://gitcode.com/gh_mirrors/ma/masa-mods-chinese 还在为Masa Mods复杂的英文界面而烦恼吗?这个专为中文玩家…...

终极NCM解密指南:3分钟解锁网易云音乐加密文件,实现跨设备自由播放

终极NCM解密指南:3分钟解锁网易云音乐加密文件,实现跨设备自由播放 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 还在为网易云音乐下载的NCM格式文件无法在其他设备播放而烦恼吗?ncmdump解密工具…...

如何快速掌握RPA文件提取:专业级游戏资源提取工具完全指南

如何快速掌握RPA文件提取:专业级游戏资源提取工具完全指南 【免费下载链接】unrpa A program to extract files from the RPA archive format. 项目地址: https://gitcode.com/gh_mirrors/un/unrpa 你是否曾因无法打开RenPy引擎打包的RPA文件而束手无策&…...