动态规划5,粉刷房子,买卖股票的最佳时期

粉刷房子

在这里插入图片描述

思路:

1.经验+题目要求

dp[i][0] 表示:粉刷到 i 位置的时候,最后一个位置粉刷上红色,此时的最小花费。
dp[i][1] 表示:粉刷到 i 位置的时候,最后一个位置粉刷上蓝色,此时的最小花费。
dp[i][2] 表示:粉刷到 i 位置的时候,最后一个位置粉刷上绿色,此时的最小花费。

2.状态转移方程

因为相邻两个房子颜色不能相同,所以我们粉刷下一个位置只需要 找出上一个位置粉刷另外两种颜色最小花费即可。
比如: i 位置是红色,那么 i -1 只能是蓝和绿 ,找出min(dp[i-1][1] , dp[i-1][2]);
在这里插入图片描述
3.
有 i -1 ,建表多建一行/一列,要求最小花费,初始化为0即可不影响填表
在这里插入图片描述

4 .
从左往右填表,一次填三个表

class Solution {
public:int minCost(vector<vector<int>>& costs) {int n = costs.size();vector<vector<int>> dp(n+1,vector<int>(3));for(int i = 1; i<=n; i++){dp[i][0] = min(dp[i-1][1],dp[i-1][2]) +costs[i-1][0];dp[i][1] = min(dp[i-1][0],dp[i-1][2]) +costs[i-1][1];dp[i][2] = min(dp[i-1][0],dp[i-1][1]) +costs[i-1][2];}return min(min(dp[n][0],dp[n][1]),dp[n][2]);}
};

买卖股票的最佳时机含冷冻期

在这里插入图片描述

思路:

1.经验+题目要求

粉刷房子用颜色来表示的表,买卖股票可以用状态表示。

dp[i][0] 表示:第 i 天结束以后,处于" 买入 " 状态,此时的最大利润。
dp[i][1] 表示:第 i 天结束以后,处于" 可交易 " 状态,此时的最大利润。
dp[i][2] 表示:第 i 天结束以后,处于" 冷冻期 " 状态,此时的最大利润。

2.状态转移方程

每一个状态都可以由 另一个状态 转变成:买入 可以 从买入,可交易转换成。
例如: 买入 状态可以 当天啥也不干还是买入,也可以从可交易状态到买入,找出这两个状态的最大值即可。

在这里插入图片描述

  1. 初始化

只有买入状态的初始化,因为买入了所以为-p[0];

dp[0][0] = -p[0] , dp[0][1] = 0 , dp[0][2] = 0;

4.从左往右填写,一次填写三个表

class Solution {
public:int maxProfit(vector<int>& prices) {int n = prices.size();vector<vector<int>> dp(n+1,vector<int>(3));dp[0][0] = -prices[0];for(int i = 1; i<n; i++){dp[i][0] = max(dp[i-1][0],dp[i-1][1] - prices[i]);dp[i][1] = max(dp[i-1][1],dp[i-1][2]);dp[i][2] = dp[i-1][0] + prices[i];}return max(max(dp[n-1][0],dp[n-1][1]),dp[n-1][2]);}
};

买卖股票的最佳时机含手续费

在这里插入图片描述
思路:

1.经验+题目要求

粉刷房子用颜色来表示的表,买卖股票可以用状态表示。

f[i] 表示:第 i 天结束之后,处于"买入" 状态,此时的最大利润
g[i] 表示:第 i 天结束之后,处于"卖出" 状态,此时的最大利润

注意手续费的位置,手续费的位置在从买入到卖出状态转换的位置上。
在这里插入图片描述

在这里插入图片描述
4.从左往右填写,两个表一起填

class Solution {
public:int maxProfit(vector<int>& prices, int fee) {int n = prices.size();vector<int> f(n);auto g = f;f[0] = -prices[0];for(int i = 1; i<n; i++){f[i] = max(f[i-1],g[i-1]- prices[i] );g[i] = max(g[i-1],f[i-1] + prices[i] -fee);}return max(f[n-1],g[n-1]);}
};

买卖股票的最佳时机 III

在这里插入图片描述
思路:

1.经验+题目要求
在这里插入图片描述

f[i][j] 表示:第 i 天结束之后,完成了 j 次交易,此时处于" 买入 " 状态下的最大利润
g[i][j] 表示:第 i 天结束之后,完成了 j 次交易,此时处于" 卖出 " 状态下的最大利润

状态之间的转换表达的状态转移方程和上面那几道题一样,但是,在判断 g[i][j] 的时候,需要注意j-1,j-1需要额外判断,
if(j-1) >=0 才能是 max状态转移方程,当j == 0时候,g[i][j] = g[i-1][j];

在这里插入图片描述

为了不影响max操作的比较,在第0天的时候,给第1和2次交易设为负无穷,但是又因为 上面 有g[i-1][j] - p[i] , 如果设为
INT_MIN ,就会超出范围,所以设为 -0x3f3f3f3f 。

在这里插入图片描述

4.从上往下填写每一行,两个表一起填写。

在这里插入图片描述

class Solution {
public:int maxProfit(vector<int>& prices) {int n = prices.size();vector<vector<int>> f(n,vector<int>(3));auto g = f;//f表初始化f[0][0] = -prices[0];for(int i = 1; i<3; i++){f[0][i] = -0x3f3f3f3f; //不能用INT_MIN,因为再+-都会超出极限g[0][i] = -0x3f3f3f3f;}//填表for(int i = 1; i<n; i++){for(int j = 0; j<3; j++){f[i][j] = max(f[i-1][j],g[i-1][j] - prices[i]);if(j-1 >=0)g[i][j] = max(g[i-1][j],f[i-1][j-1]+prices[i]);elseg[i][j] = g[i-1][j];}}int ret = 0;for(int i = 0; i<3; i++){ret = max(ret,g[n-1][i]);}return ret;}
};

买卖股票的最佳时机 IV

在这里插入图片描述

同 买卖股票的最佳时机 III,就留给练习上一题了。

class Solution {
public:int maxProfit(int k, vector<int>& prices) {int n = prices.size();vector<vector<int>> f(n,vector<int>(k+1));auto g = f;f[0][0] = -prices[0];for(int i = 1; i<k+1; i++){f[0][i] = -0x3f3f3f3f;g[0][i] = -0x3f3f3f3f;}for(int i = 1; i<n; i++){for(int j = 0; j<k+1; j++){f[i][j] = max(f[i-1][j],g[i-1][j] -prices[i]);if(j-1 >= 0)g[i][j] = max(g[i-1][j],f[i-1][j-1]+prices[i]);elseg[i][j] = g[i-1][j];}}int ret = 0;for(int i = 0; i<k+1; i++){ret = max(ret,g[n-1][i]);}return ret;}
};

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

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

相关文章

java学习(常用类)

一、包装类&#xff08;针对八种基本数据类型相应的引用类型--包装类. 1)包装类和基本数据类型的相互转换 装箱&#xff1a;基本类型->包装类型 拆箱&#xff1a;包装类型->基本类型 //以下是int类型和char类型演示。 public class temp1 {public static void main(St…

TOMCAT的安装与基本信息

一、TOMCAT简介 Tomcat 服务器是一个免费的开放源代码的Web 应用服务器&#xff0c;属于轻量级应用服务器&#xff0c;在中小型系统和并发访问用户不是很多的场合下被普遍使用&#xff0c;是开发和调试JSP 程序的首选。对于一个初学者来说&#xff0c;可以这样认为&#xff0c…

Rust调用同级目录中的rs文件和调用下级目录中的rs文件

一、Rust调用同级目录中的rs文件 Rust新建工程demo02&#xff0c;src文件夹下面新建test.rs文件&#xff0c;这样main.rs文件与它属于同级目录中。 关键点&#xff1a;导入test文件和test文件中的Ellipse模块 mod test;//导入test模块&#xff08;文件&#xff09; use test…

MySQL-MHA搭建、故障测试

一、架构说明 MHA&#xff08;Master High Availability&#xff09;是一个用于 MySQL 主从复制管理和自动故障转移的开源工具集。MHA 的主要目的是提供 MySQL 环境的高可用性和自动故障转移功能&#xff0c;确保在主库发生故障时能够快速切换到备库&#xff0c;降低业务中断时…

Android 性能优化--APK加固(1)混淆

文章目录 为什么要开启混淆如何开启代码混淆如何开启资源压缩代码混淆配置代码混淆后&#xff0c;Crash 问题定位结尾 本文首发地址&#xff1a;https://h89.cn/archives/211.html 最新更新地址&#xff1a;https://gitee.com/chenjim/chenjimblog 为什么要开启混淆 先上一个 …

架构设计:生产消费模型

1. 引言 在现代软件系统中&#xff0c;处理大量数据和消息是一项重要的任务。生产消费模型作为一种经典的并发模式&#xff0c;在解决数据生产和消费之间的关系上发挥着关键作用。该模型通过有效地管理生产者和消费者之间的通信和数据流动&#xff0c;实现了系统组件之间的解耦…

LASSO算法

LASSO (Least Absolute Shrinkage and Selection Operator) 是一种回归分析的方法&#xff0c;它能够同时进行变量选择和正则化&#xff0c;以增强预测准确性和模型的解释性。LASSO通过在损失函数中加入一个L1惩罚项来实现这一点。该惩罚项对系数的绝对值进行约束。 基本概念 …

python中的类与对象(3)

目录 一. 类的多继承 二. 类的封装 三. 类的多态 四. 类与对象综合练习&#xff1a;校园管理系统 一. 类的多继承 在&#xff08;2&#xff09;第四节中我们介绍了什么是类的继承&#xff0c;在子类的括号里面写入要继承的父类名。上一节我们只在括号内写了一个父类名&…

【详识JAVA语言】面向对象程序三大特性之三:多态

多态 多态的概念 多态的概念&#xff1a;通俗来说&#xff0c;就是多种形态&#xff0c;具体点就是去完成某个行为&#xff0c;当不同的对象去完成时会产生出不同的状态。 多态实现条件 在java中要实现多态&#xff0c;必须要满足如下几个条件&#xff0c;缺一不可&#xf…

基于阿里云OSS上传图片实战案例

一、案例描述 基于Springboot框架实现一个上传图片到阿里云服务端保存的小案例。 二、准备工作 基于Springboot免费搭载轻量级阿里云OSS数据存储库&#xff08;将本地文本、照片、视频、音频等上传云服务保存&#xff09;-CSDN博客 三、代码 新建这两个类&#xff1a;一个…

【数据结构初阶】九、五种比较排序的讲解和实现(直接插入 \ 希尔 \ 直接选择 \ 堆 \ 冒泡 -- C语言)

相关代码gitee自取&#xff1a; C语言学习日记: 加油努力 (gitee.com) 接上期&#xff1a; 【数据结构初阶】八、非线性表里的二叉树&#xff08;二叉树的实现 -- C语言链式结构&#xff09;-CSDN博客 排序 排序的概念 所谓排序&#xff0c;就是使一串记录&#xff0c;按照…

网络编程(IP、端口、协议、UDP、TCP)【详解】

目录 1.什么是网络编程&#xff1f; 2.基本的通信架构 3.网络通信三要素 4.UDP通信-快速入门 5.UDP通信-多发多收 6.TCP通信-快速入门 7.TCP通信-多发多收 8.TCP通信-同时接收多个客户端 9.TCP通信-综合案例 1.什么是网络编程&#xff1f; 网络编程是可以让设…

Web开发学习-HTML

第一天 固定结构 如何注释&#xff1a;vs code中使用ctrl/可以达到注释这一行的效果&#xff0c;同时再次按下ctrl/&#xff0c;可以取消注释。 HTML标签的结构 例如&#xff1a;<strong>字体加粗</strong>这个就是双标签&#xff0c;<br>换行标签&#xff…

[RoarCTF 2019]Easy Calc

这题考查的是: 字符串解析特性目录读取文件内容读取 字符串解析特性详解&#xff1a;PHP字符串解析特性 &#xff08;$GET/$POST参数绕过&#xff09;&#xff08;含例题 buuctf easycalc&#xff09;_参数解析 绕过-CSDN博客 ascii码查询表&#xff1a;ASCII 表 | 菜鸟工具 …

flurl升级之后没有FlurlNewtonsoftJsonSerializer

新建NewtonsoftJsonSerializer.cs /// <summary> /// ISerializer implementation based on Newtonsoft.Json. /// Default serializer used in calls to GetJsonAsync, PostJsonAsync, etc. /// </summary> public class NewtonsoftJsonSerializer : IJsonSerial…

【贪心算法】Leetcode 455.分发饼干 376. 摆动序列 53. 最大子数组和

【贪心算法】Leetcode 455 分发饼干 376. 摆动序列【规律很多】53. 最大子数组和 455 分发饼干局部最优推全局最优&#xff1a;尽量用大饼干去满足大胃口的小朋友 376. 摆动序列【规律很多】思想&#xff1a;注意考虑一个坡度留首尾两个点、平坡、首尾 53. 最大子数组和【好思想…

18个惊艳的可视化大屏(第12辑):智慧校园与教育方向

智慧校园可视化大屏通过数据可视化技术&#xff0c;将学校各个方面的数据信息进行展示&#xff0c;可以提高信息公开透明度、优化校园管理、提高学生教育质量和提高校内活动宣传效果等。 1提高信息公开透明度&#xff1a; 通过大屏幕展示校园各个方面的数据信息&#xff0c;可…

MyBatisPlus(SpringBoot版)的分页插件

目录 一、前置工作: 1.整体项目目录结构 2.创建普通javamaven项目。 3.导入依赖&#xff0c;改造成springboot项目 4.配置启动类 5.创建service接口及其实现类 6.创建接口Mapper 7.配置数据源 8.创建数据库表 二、使用MP&#xff08;mybatisplus&#xff09;的分页插件 二、使…

COMPOSER安装使用WIN下升级PHP-V

想用TP6使用phpspreadsheet但是说我PHP版本低&#xff0c;原来是PHP7.0 composer要求至少7.4 直接修改环境变量&#xff0c;把PHP目录切换到7.4 composer升级比较简单&#xff0c;在PHP目录下CMD然后官网的命令执行下即可 下面就可以在TP根目录下执行命令安装PHPSPREADSHEET…

Docker数据集与自定义镜像:构建高效容器的关键要素

目录 博客前言 一.数据卷 1.数据卷介绍 2.实战 宿主机和容器共享目录 容器和容器之间共享目录 二.自定义镜像 1.自定义镜像介绍 2.实战 2.1自定义centos&#xff0c;具备vim及ifconfig作用 构建镜像 通过镜像运行一个容器进行测试 2.2自定义tomact&#xff08;文件为…