代码随想录算法训练营第四十八天|LeetCode121 买卖股票的最佳时机、LeetCode122 买卖股票的最佳时机II

121.买卖股票的最佳时机

思路:只能购买一次股票,确定dp数组及其下标含义dp[i][0]表示第i天持有股票的最大钱数,dp[i][1]表示第i天不持有股票的最大钱数,递推公式,第i天不持有股票的最大钱数有两种情况,1、第i天卖出了股票,dp[i-1][0]+prices[i],2、第i天之前没买股票,第i天也不买,dp[i-1][1],所以dp[i][1]=max(dp[i-1][0]+prices[i],dp[i-1][1]); 第i天持有股票的最大钱数也有两种情况,1、第i天买入股票:-prices[i],第i 天之前买入了股票,dp[i-1][0]。dp[i-1][0] = max(-prices[i],dp[i-1][0]). 初始化,第0天持有股票dp[0][0] = -prices[0].第0天不持有股票 dp[0][1] = 0; 遍历顺序,从前往后。 打印dp数组,可以用于debug。

class Solution {
public:int maxProfit(vector<int>& prices) {//确定dp数组及其下标的含义 dp[i][0] 表示第i天持有股票的最大钱数, dp[i][1]表示第i天不持有股票的最大钱数//递推公式 dp[i][0] = max(-prices[i],dp[i-1][0]); //当前天持有股票的最大钱数,为前一天持有股票的钱数,与今天才开始买股票的钱数的最大值//递推公式 dp[i][1] = max(dp[i-1][0]+prices[i],dp[i-1][1]); //当天不持有股票的最大钱数,为前一天持有股票钱数,今天卖了,与前一天就不持有,今天也不买的最大值//初始化 dp[0][0]=-prices[0]; 第一天就持有股票//dp[0][1] = 0;第一天不持有股票//遍历顺序,从小到大//打印dp数组,可以用于debugint size = prices.size();vector<vector<int>> dp(size,vector<int> (2,0));dp[0][0] = -prices[0];for(int i = 1;i<prices.size();i++){dp[i][0] = max(-prices[i],dp[i-1][0]);dp[i][1] = max(dp[i-1][0]+prices[i],dp[i-1][1]); }if(dp[prices.size()-1][1]>=0){return dp[prices.size()-1][1];}else{return 0;}}
};

122.买卖股票的最佳时机 II

思路:这道题与当一题的区别在于可以多次购买股票,这道题用贪心算法,计算每天的利润值,求正数的和也可以得到。动态规划的思想与上一题相同,但递推公式不同,因为可以多次购买股票,因此,第i天持有股票的最大金额有两种情况:1、前一天不持有股票,今天刚买。dp[i-1][1]-prices[i]。2、前一天持有股票,今天不买 dp[i-1][0] = max( dp[i-1][1]-prices[i],dp[i-1][0]).第i天不持有股票也有两种情况:1、前一天持有股票,今天卖出.dp[i-1][0]+prices[i].2、前一天不持有股票,今天也不买,dp[i-1][1];dp[i][1] = max(dp[i-1][0]+prices[i],dp[i-1]); 主要区别在于第i天持有股票的最大金额的递推公式,因为上一题只能买一次,所以之前不买股票的本金就是0,今天买了,就直接-prices[i],而此题可以多次买卖,当前买股票时,之前经历过买卖,手中的本金为dp[i-1][1]。

lass Solution {
public:int maxProfit(vector<int>& prices) {int size = prices.size();vector<vector<int>> dp(size,vector<int> (2,0));dp[0][0] = -prices[0];for(int i = 1;i<prices.size();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][0]+prices[i]);}return dp[prices.size()-1][1];}
};

收获:

只能买一次和多次的区别就在于,买股票时手里的本金是0还是之前买卖过股票后的金额、

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

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

相关文章

如何使用Python进行数据可视化:Matplotlib和Seaborn指南【第123篇—Matplotlib和Seaborn指南】

如何使用Python进行数据可视化&#xff1a;Matplotlib和Seaborn指南 数据可视化是数据科学和分析中不可或缺的一部分&#xff0c;而Python中的Matplotlib和Seaborn库为用户提供了强大的工具来创建各种可视化图表。本文将介绍如何使用这两个库进行数据可视化&#xff0c;并提供…

element-plus表格,多样本比较,动态渲染表头

问题&#xff1a; 公司给了个excel表格&#xff0c;让比较两个样本之间的数据&#xff0c;并且动态渲染&#xff0c;搞了半天没搞出来&#xff0c;最后让大佬解决了&#xff0c;特此写篇博客记录一下。 我之前的思路是合并行&#xff0c;大概效果是这样&#xff1a; 但是最终…

DataGrip 面试题及答案整理,最新面试题

DataGrip的数据库兼容性和多数据库支持如何实现&#xff1f; DataGrip实现数据库兼容性和多数据库支持的方式包括&#xff1a; 1、广泛的数据库支持&#xff1a; DataGrip支持多种数据库&#xff0c;包括但不限于MySQL, PostgreSQL, SQL Server, Oracle, SQLite, 和MongoDB&a…

ChatGPT团队:介绍OpenAI团队生产力提升工具

ChatGPT团队&#xff1a;OpenAI团队生产力提升器 概述 随着人工智能&#xff08;AI&#xff09;在业务工作流程中的日益普及&#xff0c;OpenAI最近推出了ChatGPT团队订阅计划&#xff0c;该计划在各类组织中获得了广泛的关注。ChatGPT团队是一个AI驱动的平台&#xff0c;彻底…

小米笔记本出现no bootable devices

原因&#xff1a;硬件松动 解决方案&#xff1a; 1、不妨翻个面敲几下&#xff0c;上下左右晃晃试试 2、这个问题也困扰我好久了 搜了好多答案说是硬盘出了问题 前几次就是摇一摇&#xff0c;拍一拍就好了 后来怎么拍也没有用了 没办法自己动手&#xff0c;买一套螺丝刀&…

Docker----Dockerfile构建微服务镜像

目录 一、关键步骤 二、具体步骤 1、准备后端jar包(这里以java后端演示) 2、编写Dockerfile 3、构建镜像 4、运行镜像容器 5、测试是否成功 一、关键步骤 1、准备后端jar包(这里以java后端演示) 2、编写Dockerfile 3、构建镜像 4、运行镜像容器 5、测试是否成功 二…

c++排序算法

冒泡排序 //冒泡 通过多次交换相邻元素将较大&#xff08;或较小&#xff09;的元素逐渐 "浮" 到数组的一端。该算法的时间复杂度为 O(N^2)。 void bubbleSort(vector<int>&arr) {int narr.size();for(int i0; i<n-1; i) {for(int j0; j<n-i-1; j) …

突破编程_C++_查找算法(插值查找)

1 算法题 &#xff1a;使用插值查找算法在有序数组中查找指定元素 1.1 题目含义 使用插值查找算法在有序数组中查找指定元素。插值查找是介于线性查找和二分查找之间的一种查找算法&#xff0c;它是基于二分查找的改进算法。插值查找的核心思想在于根据待查找元素的值在有序数…

Web前端依赖版本管理最佳实践

本文需要读者懂一点点前端的构建知识&#xff1a; 1. package.json文件的作用之一是管理外部依赖&#xff1b;2. .npmrc是npm命令默认配置&#xff0c;放在工程根目录。 Web前端构建一直都是一个不难&#xff0c;但是非常烦人的问题&#xff0c;在DevOps、CI/CD领域。 烦人的是…

Java的SPI机制与实例

Java的SPI机制与实例 是什么&#xff1f; SPI是一种JDK内置的服务提供发现的机制&#xff0c;能够启动框架扩展和替换组件&#xff0c;主要是被框架的开发人员使用&#xff0c;比如java.sql。Driver接口。Java机制的核心思想就是将装配的控制权转移到Java之外&#xff0c;核心…

HTTPS证书很贵吗?

首先&#xff0c;我们需要明确一点&#xff0c;HTTPS证书的价格并不是一成不变的&#xff0c;它受到多种因素的影响。其中最主要的因素包括证书的类型、颁发机构以及所需的验证级别。 从类型上来看&#xff0c;HTTPS证书主要分为单域名证书、多域名证书和通配符证书。单域名证书…

远程过程调用-buttonrpc源码解析1-序列化

分析buttonrpc中的序列化 源码提供了StreamBuffer类&#xff0c;该类继承自vector<char>&#xff0c;用来存储数据。 // 此处省略实现... class StreamBuffer : public vector<char> {};并提供了Serializer类&#xff0c;用来序列化数据。 // 此处省略部分实现..…

pta上的几个例题

c语言中的小小白-CSDN博客c语言中的小小白关注算法,c,c语言,贪心算法,链表,mysql,动态规划,后端,线性回归,数据结构,排序算法领域.https://blog.csdn.net/bhbcdxb123?spm1001.2014.3001.5343 给大家分享一句我很喜欢我话&#xff1a; 知不足而奋进&#xff0c;望远山而前行&am…

1258:【例9.2】数字金字塔-----动态规划(递推)1

题目网址 1258&#xff1a;【例9.2】数字金字塔 首先解这道题我们第一眼想到是不是暴力&#xff0c;但是暴力的话是O(n!)的时间复杂度&#xff0c;很明显&#xff0c;会超时。那怎么办呢&#xff1f;不如我们把他分成若干子问题把&#xff0c;就像分治那样。 首先我们想得到答案…

vue2 项目中使用clipboard复制插件

需求&#xff0c;点击页面中的某一个按钮&#xff0c;复制文字。 npm install clipboard --save 在组件中使用 import Clipboard from clipboard html中的按钮 <div ref"main" class"main"><button click"copy">copy</button…

Android Studio实现内容丰富的安卓校园新闻浏览平台

获取源码请点击文章末尾QQ名片联系&#xff0c;源码不免费&#xff0c;尊重创作&#xff0c;尊重劳动 项目编号070 1.开发环境android stuido jdk1.8 eclipse mysql tomcat 2.功能介绍 安卓端&#xff1a; 1.注册登录 2.查看新闻列表 3.查看新闻详情 4.评论新闻 5.收藏新闻 6…

解决VMware无法检测此光盘映像中的操作系统

今天我本想在VMware上安装一个win10系统&#xff0c;可是遇到“无法检测此光盘映像中的操作系统。您需要指定要安装的操作系统。”的错误。报错如下&#xff1a; 图一 遇到的问题 开始还以为是ISO文件有问题&#xff0c;重新下载了几个还是不行&#xff08;一个ISO文件好几个G&…

免费SSL证书Let‘sEncrypt安装

1. Let’sEncrypt说明&#xff1a; Lets Encrypt 是免费、开放和自动化的证书颁发机构由Linux基金会(Linux Foundation)进行日常管理维护&#xff0c;它为36.3亿个网站提供TLS证书的非盈利性证书颁发机构, 通过它我们可以免费申请网站证书&#xff0c;并您的网站上启用 HTTPS …

APP专项测试

一、介绍 APP测试除了功能测试外&#xff0c;还需要进行一些专项测试来发现更为深层的问题&#xff0c;这些问题主要是针对某个特殊方面进行&#xff0c;如安装卸载升级测试、兼容性测试、弱网测试、中断测试、流量测试、耗电量测试等。 二 、安装卸载升级测试 APP开发后&am…

联想拯救者刃7000K2024游戏电脑主机仅售6999元

这款联想拯救者刀锋7000K 2024游戏电脑主机在京东促销中售价仅为6999元&#xff0c;相比原价7499元有相当大的折扣。 这是一款功能强大的游戏电脑&#xff0c;配备了全新的 15-14400(F) 处理器和 RTX™ 4060 显卡&#xff0c;以及 16GB DDR5 内存和 1TB 固态硬盘。 外观方面&a…