贪心算法-买卖股票的最佳时机

买卖股票的最佳时机

java 复制代码
给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天
的价格。

你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股
票。设计一个算法来计算你所能获取的最大利润。

返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 。

输入 :整型数组
输出 :整型变量
思路:通过求解当天与前一天的差,得到该题可以转换为求子数组的最大值

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        //定义新的数组来维护
        int[] tmpNum = new int[prices.length];
        tmpNum[0] = 0;
        //定义pre
        int pre = 0;
        int maxNum = 0;
        for(int i = 1;i < prices.length;i++){
            tmpNum[i] = prices[i] - prices[i-1];
        }
        for(int x : tmpNum){
            pre = Math.max(pre + x,x);
            maxNum = Math.max(pre,maxNum);
        }
        return maxNum;
    }
}

然后使用贪心算法

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        //每次都进行维护
        int minPrice = Integer.MAX_VALUE;
        int maxprofit = 0;
        for(int x : prices){
            //更新最大利润
            maxprofit = Math.max(maxprofit,x - minPrice);
            //更新最小值
            minPrice = Math.min(minPrice,x);
        }
        return maxprofit;
    }
}
相关推荐
岑梓铭10 分钟前
《考研408数据结构》第六章(5.1+5.2+5.3树、二叉树、线索二叉树)复习笔记
数据结构·笔记·考研·408·1024程序员节
好学且牛逼的马22 分钟前
MyBatis-Plus的深度解析
java
苏纪云24 分钟前
数据结构<C++>——数组
java·数据结构·c++·数组·动态数组
周杰伦_Jay33 分钟前
【 RocketMQ 全解析】分布式消息队列的架构、消息转发与快速实践、事务消息
分布式·算法·架构·rocketmq·1024程序员节
典则1 小时前
STM32FreeRtos入门(五)——同步互斥与通信
java·jvm·stm32
sprintzer1 小时前
10.16-10.25力扣计数刷题
算法·leetcode
你不是我我1 小时前
【Java 开发日记】我们来讲一讲阻塞队列及其应用
java·开发语言
互联网中的一颗神经元1 小时前
小白python入门 - 9. Python 列表2 ——从基础操作到高级应用
java·开发语言·python
大厂码农老A1 小时前
我带的外包兄弟放弃大厂转正,薪资翻倍入职字节
java·后端·面试
王哈哈^_^1 小时前
【数据集】【YOLO】【目标检测】建筑垃圾数据集 4256 张,YOLO建筑垃圾识别算法实战训推教程。
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·数据集