力扣121题: 买卖股票的最佳时机

【题目描述】

        给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子卖出该股票。设计一个算法来计算你所能获取的最大利润。返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 

【题目链接】. - 力扣(LeetCode)

【解题代码】

public class MaxProfit {public static void main(String[] args) {//int[] prices = {7, 1, 5, 3, 6, 4};int[] prices = {7, 6, 4, 3, 1};System.out.println("The result is: " + new MaxProfit().maxProfit(prices));}public int maxProfit(int[] prices) {// 定义动态规划中间过程数组int dp[] = new int[prices.length];// 初始化历史最低股价int minPrice = prices[0];// 初始化历史最大收益int maxProfit = 0;for (int i = 1; i < prices.length; i++) {// 当天最大收益等于当前股价减去初始化历史最低股价dp[i] = prices[i] - minPrice;// 当天股价如果低于历史最低股价,更新历史最新股价minPrice = Math.min(minPrice, prices[i]);// 保存到当天为止,最大的收益maxProfit = Math.max(maxProfit, dp[i]);}return maxProfit;}}

【解题步骤】

  1. 从题目描述可以得知,此问题是要根据历史依次往后计算当天的最大股票收益值,很自然的想到采用动态规划的算法,因此照例定义一个动态规划数组
    // 定义动态规划中间过程数组
    int dp[] = new int[prices.length];
  2. 再次根据题目可知,当天收益等于当天的股价减去历史最低股价。然后依次保存最大的收益即可,因此需要定义历史最低股价和历史最大收益两个变量
    // 初始化历史最低股价
    int minPrice = prices[0];
    // 初始化历史最大收益
    int maxProfit = 0;  
  3. 接下来就是按照动态规划的算法,依次计算中间过程,并不断更新历史最低股价和历史最大收益即可
    // 依次计算每天的最大收益
    for (int i = 1; i < prices.length; i++) {// 当天最大收益等于当前股价减去初始化历史最低股价dp[i] = prices[i] - minPrice;// 当天股价如果低于历史最低股价,更新历史最新股价minPrice = Math.min(minPrice, prices[i]);// 保存到当天为止,最大的收益maxProfit = Math.max(maxProfit, dp[i]);
    }
  4. 最后返回最大收益值即可
    return maxProfit;

【思路总结】

  1. 动态规划算法是数据结构中一个很重要的算法,另外一般学校里教的都很浅薄,程序员一定要自学掌握其算法脉络,并能学会灵活运用;
  2. 动态规划数组的做法一般都是定义个一维或者二维数据,依次递推计算当前数值;
  3. 无后效性递推算法一般只需要考虑眼前最近一层,其它层一定不需要考虑。“未来与过去无关

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

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

相关文章

Mathtype安装时word启动显示“文件未找到:MathPage.WLL”

背景 由于老板布置的临时工作&#xff0c;需要安装Mathtype&#xff0c;但尝试了3个不同的版本后&#xff08;每次都卸载干净了&#xff09;&#xff0c;均未能成功安装&#xff0c;出现的报错3个版本各不相同&#xff1a; ①解压安装过程中失败&#xff08;这个版本不再尝试…

GoFrame:如何简单地搭建一个简单地微服务

一切资料来源于GoFrame官网, 感兴趣的, 可以直接去官网查阅相关资料。 首先下载框架工具, 下载地址:https://github.com/gogf/gf/releases 然后进入你想要放置的项目文件夹, 执行命令行 gf init {project_name} #project_name为你的项目名 执行完后项目结构如图所示 然…

同等学力申硕专业介绍——教育学硕士

同等学力申硕的专业很多。 目前有十三大门类&#xff0c;分别是医学、法学、管理学、工学、教育学、经济学、艺术学、文学、历史学、理学、哲学、农学、军事学等&#xff0c;每个大门类中都有很多的细分专业。 今天为大家介绍同等学力申硕专业——教育学。 专业介绍 教育学该…

基于java+springboot动物检疫信息管理系统设计和实现

基于java SSM springboot动物检疫信息管理系统设计和实现 博主介绍&#xff1a;多年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《1000套》 欢迎点赞 收藏 ⭐留言 文…

【寸铁的刷题笔记】树、dfs、bfs、回溯、递归(三)

【寸铁的刷题笔记】树、dfs、bfs、回溯、递归(三) 大家好 我是寸铁&#x1f44a; 金三银四&#xff0c;树、dfs、bfs、回溯、递归是必考的知识点✨ 快跟着寸铁刷起来&#xff01;面试顺利上岸&#x1f44b; 喜欢的小伙伴可以点点关注 &#x1f49d; 530. 二叉搜索树的最小绝对差…

考研政治这样复习更高效

政治复习是考研备考中的重要一环&#xff0c;需要考生制定科学的复习计划&#xff0c;注重知识点的掌握和解题技巧的提升。以下是一些政治复习的建议&#xff1a; 梳理知识框架&#xff1a;首先&#xff0c;需要梳理政治学科的知识框架&#xff0c;了解各个章节之间的内在联系…

【Vue3】自定义 Vue3 插件(全局实现页面加载动画)

// main.ts import { createApp } from vue import App from ./App.vue import Loading from "./components/Loading/index.ts";const app createApp(App) type Lod {show: () > void,hide: () > void } //编写ts loading 声明文件放置报错 和 智能提示 decl…

python实现常见一元随机变量的概率分布

一. 随机变量 随机变量是一个从样本空间 Ω \Omega Ω到实数空间 R R R的函数&#xff0c;比如随机变量 X X X可以表示投骰子的点数。随机变量一般可以分为两类&#xff1a; 离散型随机变量&#xff1a;随机变量的取值为有限个。连续型随机变量&#xff1a;随机变量的取值是连…

Redis 群集部署

1.关系型数据库 关系型数据库是一个结构化的数据库&#xff0c;创建在关系模型基础上&#xff0c;-般面向记录。它借助于集合代数等数学概念和方法来处理数据库中的数据。关系模型指二维表格模型,因而一个关系型数据库就是由二维表及其之间的联系组成的一个数据组织。现实世界中…

python及编程范式

编程范式 编程范式是一种基于特定的理论和原则来指导程序设计和开发风格的模型。它定义了编程语言的结构、风格、元素以及编写程序时应遵循的规则。不同的编程范式提供了不同视角来解决问题&#xff0c;影响着代码组织方式、执行流程以及如何表达程序逻辑。 OOP和FP 函数式编…

vue3监听input保留两位小数点

监听input输入框校验 再次记录下&#xff0c;这里没封装&#xff0c;仅演示~ 保留2位小数 只能输入数字和两位小数 <el-inputv-model"form.amount"oninput"valuevalue.replace(/[^0-9.]/g,).replace(/\.{2,}/g,.).replace(/^(\-)*(\d)\.(\d\d).*$/,$1$2.$3…

(2024,MixLoRA,任务干扰,独立因子选择,条件因子选择)使用 LoRA 的条件混合进行多模态指令调优

Multimodal Instruction Tuning with Conditional Mixture of LoRA 公和众和号&#xff1a;EDPJ&#xff08;进 Q 交流群&#xff1a;922230617 或加 VX&#xff1a;CV_EDPJ 进 V 交流群&#xff09; 目录 0. 摘要 3. 任务干扰在多模态指令调优中的 LoRA 应用 3.1 背景&am…

小甲鱼Python07 函数初级

一、创建和调用函数 pass语句表示一个空的代码块&#xff0c;我们经常先写好函数&#xff0c;pass占一个坑&#xff0c;等规划好之后再来填坑。 函数也是可以指定参数的&#xff0c;我们会把参数传进去用来替代形参。 在Python里如果想要返回值&#xff0c;不需要指定函数的返…

仿牛客网项目---显示评论和添加评论功能的实现

这篇文章&#xff0c;我来介绍一下我的项目中的另外一个功能&#xff1a;显示评论和添加评论。 其实这两个功能都不怎么重要&#xff0c;我感觉最重要的应该是用户注册登录功能&#xff0c;这个也了解一下&#xff0c;知道这么一回事儿就好。 首先设计DAO层。 Mapper public …

python实现AES加密解密

1. 前言 AES是一种对称加密&#xff0c;所谓对称加密就是加密与解密使用的秘钥是一个。 之前写过一片关于python AES加密解密的文章&#xff0c;但是这里面细节实在很多&#xff0c;这次我从 参数类型、加密模式、编码模式、补全模式、等等方面 系统的说明如何使用AES加密解密…

直观理解卷积

卷积直观理解 原文来自最容易理解的对卷积(convolution)的解释 &#x1f3ac;个人简介&#xff1a;一个全栈工程师的升级之路&#xff01; &#x1f4cb;个人专栏&#xff1a;计算机杂记 &#x1f380;CSDN主页 发狂的小花 &#x1f304;人生秘诀&#xff1a;学习的本质就是极致…

从经典学习 NLP:小白到大白:1. Word Tokenization

文章目录 1 Word Tokenization1.1 Top-down/rule-based tokenization1.2 Byte-pair Encoding: A Bottom-up tokenization algorithm 1 Word Tokenization 来源&#xff1a;JM3 Chapter 2.5 p19-23 tokenization 就是 把 running text 分割成为 words&#xff1b; 常有两种方…

AVL 树

AVL树的概念 二叉搜索树虽可以缩短查找的效率&#xff0c;但如果数据有序或接近有序二叉搜索树将退化为单支树&#xff0c;查找元素相当于在顺序表中搜索元素&#xff0c;效率低下。因此&#xff0c;两位俄罗斯的数学家G.M.Adelson-Velskii和E.M.Landis在1962年 发明了一种解决…

k8s笔记26--快速实现prometheus监控harbor

k8s笔记26--快速实现prometheus监控harbor 简介采集指标&配置grafana面板采集指标配置grafana面板 说明 简介 harbor是当前最流行的开源容器镜像仓库项目&#xff0c;被大量IT团队广泛应用于生产、测试环境的项目中。本文基于Harbor、Prometheus、Grafana介绍快速实现监控…

3. 台阶问题

数楼梯 题目描述 楼梯有 N N N 阶&#xff0c;上楼可以一步上一阶&#xff0c;也可以一步上二阶。 编一个程序&#xff0c;计算共有多少种不同的走法。 输入格式 一个数字&#xff0c;楼梯数。 输出格式 输出走的方式总数。 样例 #1 样例输入 #1 4样例输出 #1 5提示…