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

[leetcode] 动态规划

背包

先啃懂 背包九讲

01背包,即物品有限。

for 物品for 容量(倒序)
  • P1048 [NOIP2005 普及组] 采药 [ 原题 | 题解 ]
  • P1049 [NOIP2001 普及组] 装箱问题 [ 原题 | 题解 ]
  • P1507 NASA的食物计划 [ 原题 | 题解 ]
  • P1510 精卫填海 [ 原题 | 题解 ]

完全背包,即物品无限。

for 物品for 容量(正序)

注意,爬楼梯(LeetCode 70) 要求序列有序,然而一般的完全背包不需要有序,如经典的凑硬币:面试题 08.11. 硬币。要注意这两种情况的区别!前者先循环容量再循环物品,后者先循环物品再循环容量。

  • P1832 A+B Problem(再升级)[ 原题 | 题解 ]

  • 零钱兑换( LeetCode 322 )

  • 零钱兑换 II( LeetCode 518 )

  • 组合总和 Ⅳ(leetcode 377)

  • 完全平方数( LeetCode 279 )

  • 单词拆分(leetcode 139)

分组背包。物品被划分为若干组,每组中的物品互相冲突,最多选一件。

for 组号for 容量for 组内物品
  • P1757 通天之分组背包 [ 原题 | 题解 ]

多重背包,第 i 种物品最多有 n[i] 件可用。是分组背包的一种特殊情况,这么理解:对于第 i 种物品,只能选择 0,1,2,3,4…n[i] 其中一种情况。

for 物品种类for 容量for 该类物品数量

如果超时,则需要二进制优化为 01 背包

  • P2066 机器分配 [ 原题 | 题解 ]
  • P1776 宝物筛选 [ 原题 | 题解 ]

混合背包

有的物品有无穷个(完全),有的物品是有限的(多重)。先处理完全背包,再把多重背包进行二进制优化转为 01 背包。

  • P1833 樱花 [ 原题 | 题解 ]

满足某个条件的背包

  • P1509 找啊找啊找GF [ 原题 | 题解 ]

二维 true false 背包

  • P1877 [HAOI2012] 音量调节 [ 原题 | 题解 ]

投资股票,多次 dp

  • P1853 投资的最大效益 [ 原题 | 题解 ]

动态规划

先记录最近遇到的状态dp。

  • 打家劫舍( LeetCode 198 )[ 原题 题解 ]
  • 打家劫舍(升级题目,选中 i 后,i-2,i-1,i+1,i+2 不能选,问能偷的最大价值)[原题 题解]
  • 打家劫舍(升级题目,可以偷连续2个住户,但是不能偷连续3个住户,问能偷的最大价值)[原题 题解]
  • 打家劫舍(升级题目,不能偷连续住户,但有 k 次可以偷连续住户的机会,问能偷的最大价值)[原题 题解]
  • 打家劫舍III( LeetCode 337 )[原题 题解]
  • 买卖股票的最佳时机III( LeetCode 123 )
  • 买卖股票的最佳时机IV( LeetCode 188 )
  • 最佳买卖股票时机含冷冻期(LeetCode 309)[ 原题 题解 ]

相关文章:

[leetcode] 动态规划

背包 先啃懂 背包九讲 01背包,即物品有限。 for 物品for 容量(倒序)P1048 [NOIP2005 普及组] 采药 [ 原题 | 题解 ] P1049 [NOIP2001 普及组] 装箱问题 [ 原题 | 题解 ] P1507 NASA的食物计划 [ 原题 | 题解 ] P1510 精卫填海 [ 原题 | 题…...

科大奥瑞物理实验——热电偶特性及其应用研究

实验名称:热电偶特性及其应用研究 1. 实验目的: 掌握电位差计的工作原理和结构特点;了解温差电偶测温的原理和方法;学会电位差计的使用及注意事项。 2. 实验器材: 电位差计 标准电池 光电检流计 稳压电源 温差电偶…...

Eclips快捷键大全(超详细)

Eclips快捷键大全(超详细)前言一、常用快捷键二、编辑快捷键三、导航快捷键四、运行和调试快捷键五、重构快捷键六、代码生成快捷键七、项目导航快捷键八、帮助快捷键九、搜索快捷键十、标记快捷键十一、版本控制快捷键十二、其它快捷键前言 本博主将用C…...

整懵了,蚂蚁金服4面成功拿下测开offer,涨薪10k,突然觉得跳槽也不是那么难

蚂蚁的面试挺独特的,每轮面试都没有HR约时间,一般是晚上8点左右面试官来一个电话,问是否能面试,能的话开始面,不能就约一个其他时间。 全程4面,前四面技术面,电话面试,最后一面是HR面…...

C++内存分布malloc-free-new-delete的区别和联系

目录 一、内存分布 1.1内存分布图: 1.2 为什么要将bss和data区分开呢? 1.3 堆和栈有什么区别 二、malloc、free;new、delete 2.1 new和delete是如何实现的,new与malloc的异同处 2.2既然有了malloc/free,C为什么还…...

【华为OD机试 2023最新 】 最多颜色的车辆(C++ 100%)

文章目录 题目描述输入描述输出描述用例题目解析C++题目描述 在一个狭小的路口,每秒只能通过一辆车,假设车辆的颜色只有 3 种,找出 N 秒内经过的最多颜色的车辆数量。 三种颜色编号为0 ,1 ,2 输入描述 第一行输入的是通过的车辆颜色信息 [0,1,1,2] 代表4 秒钟通过的车…...

Linux安全加固

一、重要文件 /etc/passwd #记录本地用户的属性信息,如UID、GID /etc/shadow #存放用户的口令信息 只有系统管理员能查看 /etc/pam.d/system-auth #账户安全配置文件 /etc/login.defs #修改登录的配置文件 /etc/profile …...

Java基础学习(6)

Java基础学习一 字符串1.1 API 与 API文档1.1.1 如何使用帮助文档查找想要导用的方法1.2 String 概述1.3 创建String对象的两种方式第一种第二种1.4 Java常用字符串方法1.4.1 比较1.4.2 字符串通过索引取出1.4.3 取出字符串中的单个字符1.4.4 替换出字符串当中的字符1.4.5 取出…...

【LeetCode】链表练习 9 道题

第一题&#xff1a;移除链表元素 题目描述&#xff1a; 给你一个链表的头节点head和一个整数val&#xff0c;请你删除链表中所有满足Node.val val的节点&#xff0c;并返回新的头节点 。 列表中的节点数目在范围 [0, 10^4] 内1 < Node.val < 500 < val < 50 /…...

轴承远程监控系统解决方案

一、项目背景 随着现代机械设备朝着高集成、高精密度、系统化、自动化的方向发展&#xff0c;在工业生产中一旦机器发生故障&#xff0c;即使局部失灵&#xff0c;都可能导致设备工作失效&#xff0c;甚至造成整个自动化车间停产&#xff0c;从而给工业生产带来巨大的损失。轴承…...

阿里云轻量服务器Workbench root远程连接和一键连接的区别

阿里云轻量应用服务器远程连接支持Workbench root用户连接和Workbench一键连接&#xff0c;Workbench root需要输入root密码&#xff0c;一键连接不需要输入密码&#xff0c;但是也无法获得root权限&#xff0c;阿里云百科来详细说下阿里云轻量应用服务器远程连接说明&#xff…...

带你用纯C实现一个内存池(图文结合)

为什么要用内存池 为什么要用内存池&#xff1f;首先&#xff0c;在7 * 24h的服务器中如果不使用内存池&#xff0c;而使用malloc和free&#xff0c;那么就非常容易产生内存碎片&#xff0c;早晚都会申请内存失败&#xff1b;并且在比较复杂的代码或者继承的屎山中&#xff0c…...

ChatGPT使用案例之图像生成

ChatGPT使用案例之图像生成 这里一节我们介绍一下ChatGPT的图像生成&#xff0c;这里我们使用代码来完成&#xff0c;也就是通过API 来完成&#xff0c;因为ChatGPT 本身是不能生成图片的&#xff0c;言外之意我们图片生成是ChatGPT通过其他方式生成的 Images API提供了三种与…...

蚁群算法优化旅行问题

%%%%%%%%%%%%蚁群算法解决 TSP 问题%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%初始化%%%%%%%%%%%%%%%%%%% clear all; %清除所有变量 close all; %清图 clc; %清屏 m 50; %蚂蚁个数 Alpha 1; %信息素重要程度参数 Beta 5; %启发式因子重要程度参数 Rho 0.1; %信息素蒸发系数 G 20…...

树数据结构

什么是树数据结构&#xff1f; 树数据结构是一种层次结构&#xff0c;用于以易于导航和搜索的方式表示和组织数据。它是由边连接的节点集合&#xff0c;节点之间具有层次关系。树的最顶端的节点称为根&#xff0c;它下面的节点称为子节点。每个节点可以有多个子节点&#xff0c…...

Spring Boot整合Redis并提供多种实际场景的应用

Spring Boot整合Redis并提供多种实际场景的应用1. 整合Redis2. 场景应用2.1 缓存2.2 分布式锁2.3 计数器2.4 发布/订阅3. 总结Spring Boot是一个快速构建基于Spring框架的应用程序的工具&#xff0c;它提供了大量的自动化配置选项&#xff0c;可以轻松地集成各种不同的技术。Re…...

VR全景图片,助力VR全景制作,720全景效果图

VR全景图片是指通过全景相机或多相机组合拍摄全景画面&#xff0c;并进行拼接处理生成全景图像的过程。VR全景图片的应用范围广泛&#xff0c;包括旅游和景区、房地产、汽车、艺术和文化、电影和娱乐等领域。本文将详细介绍VR全景图片的类型、应用场景、市场前景和发展趋势。 一…...

Kali Linux20款重要软件

Kali Linux 是一个流行的网络安全测试平台&#xff0c;它包含了大量的工具和应用程序&#xff0c;以下是其中20款最常用的软件和工具&#xff1a; Metasploit&#xff1a;Metasploit 是一个广泛使用的漏洞评估工具&#xff0c;可以帮助安全专业人员测试系统中的漏洞。Aircrack…...

C语言测试五

windows是什么类型的系统&#xff08;实时还是分时&#xff09;&#xff1f;有什么区别&#xff1f; 分时操作系统。如果在单核的情况下&#xff0c;分时操作系统多个进程共用一个单核&#xff0c;该单核会将其执行时间分成相应的时间片&#xff0c;每个进程占用一定的时间片&a…...

【微服务~原始真解】Spring Cloud —— 访问数据库整合Druid数据源

&#x1f50e;这里是【秒懂云原生】&#xff0c;关注我学习云原生不迷路 &#x1f44d;如果对你有帮助&#xff0c;给博主一个免费的点赞以示鼓励 欢迎各位&#x1f50e;点赞&#x1f44d;评论收藏⭐️ &#x1f440;专栏介绍 【秒懂云原生】 目前主要更新微服务&#xff0c;…...

解密ARM多核调度:从Linux内核源码看SMP负载均衡如何玩转Cortex-A系列

ARM多核调度实战&#xff1a;从Linux内核视角剖析SMP负载均衡的艺术 在移动计算和嵌入式系统领域&#xff0c;ARM架构凭借其出色的能效比已经占据了主导地位。随着Cortex-A系列处理器核心数量的不断增加&#xff0c;如何高效地管理这些计算资源成为系统性能优化的关键。本文将带…...

等价无穷小替换的边界:为何加减法成为禁区

1. 等价无穷小替换的基本原理 第一次接触等价无穷小替换这个概念时&#xff0c;我和大多数同学一样感到困惑。为什么在计算极限时&#xff0c;x和sinx可以直接互相替换&#xff1f;为什么老师反复强调这个技巧只能在乘除法中使用&#xff1f;要理解这些问题&#xff0c;我们需要…...

ARM架构Kylin V10上Kettle部署全攻略:从驱动配置到无界面运行

ARM架构Kylin V10上Kettle部署全攻略&#xff1a;从驱动配置到无界面运行 在国产化替代浪潮中&#xff0c;ARM架构服务器搭配麒麟操作系统已成为金融、政务等关键领域的基础设施标配。然而&#xff0c;当传统ETL工具Kettle遇上这套"全国产"环境&#xff0c;从驱动兼容…...

WorkshopDL:跨平台Steam创意工坊下载器,突破平台限制获取海量模组资源

WorkshopDL&#xff1a;跨平台Steam创意工坊下载器&#xff0c;突破平台限制获取海量模组资源 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 你是否曾在Epic Games或GOG平台购…...

Go Channel 死锁问题定位技巧

Go Channel 死锁问题定位技巧 在Go语言中&#xff0c;Channel是协程间通信的核心机制&#xff0c;但使用不当容易引发死锁问题。死锁不仅会导致程序阻塞&#xff0c;还可能让开发者陷入调试困境。本文将分享几个实用的定位技巧&#xff0c;帮助开发者快速识别和解决Channel死锁…...

UNIT-00:Berserk Interface辅助数据库课程设计:从ER图到SQL

UNIT-00&#xff1a;Berserk Interface辅助数据库课程设计&#xff1a;从ER图到SQL 你是不是正在为数据库课程设计发愁&#xff1f;面对一个模糊的业务需求&#xff0c;要从零开始画出清晰的ER图&#xff0c;再设计出规范化的数据库模式&#xff0c;最后还要写出一堆建表和查询…...

MacBook安装OpenClaw实录:M1芯片适配Qwen3-32B镜像的解决方案

MacBook安装OpenClaw实录&#xff1a;M1芯片适配Qwen3-32B镜像的解决方案 1. 为什么要在M1 MacBook上折腾OpenClaw&#xff1f; 作为一个长期使用MacBook Pro&#xff08;M1芯片&#xff09;的技术爱好者&#xff0c;我一直在寻找能够充分利用本地计算资源的AI工具。当我第一…...

如何用Dify工作流引擎解决多平台内容分发效率难题

如何用Dify工作流引擎解决多平台内容分发效率难题 【免费下载链接】Awesome-Dify-Workflow 分享一些好用的 Dify DSL 工作流程&#xff0c;自用、学习两相宜。 Sharing some Dify workflows. 项目地址: https://gitcode.com/GitHub_Trending/aw/Awesome-Dify-Workflow 当…...

C#的readonly struct:不可变值类型的性能优势

在C#开发中&#xff0c;值类型的性能优化一直是开发者关注的焦点。readonly struct作为不可变值类型&#xff0c;不仅能够保证线程安全&#xff0c;还能带来显著的性能优势。本文将深入探讨readonly struct的设计原理及其在性能优化中的独特价值&#xff0c;帮助开发者更好地利…...

Java程序员,如何从零开始学习AI?

文章为Java程序员提供了零学习大模型并实现涨薪的六阶段路线&#xff1a;掌握AI基础概念、用Java调用大模型API、基于Spring AI实现轻量级AI业务场景、在真实项目中落地、学习智能体进阶技能、将AI知识融入简历。强调应聘AI应用开发工程师而非大模型工程师&#xff0c;适合文本…...