博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
算法-----买卖股票的最佳时机(Java 版本)
阅读量:2116 次
发布时间:2019-04-30

本文共 699 字,大约阅读时间需要 2 分钟。

题目 

给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。

如果你最多只允许完成一笔交易(即买入和卖出一支股票一次),设计一个算法来计算你所能获取的最大利润。

注意:你不能在买入股票前卖出股票。

示例 1:

输入: [7,1,5,3,6,4]

输出: 5
解释: 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。
     注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票。
示例 2:

输入: [7,6,4,3,1]

输出: 0
解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。

1234567891011121314151617181920 

解决方法 
其实就是求最大的差值。我们遍历每一个数字的时候,都去求当前的价格减去之前价格最低的差值,如果比之前的差值要大,那么更新差值,否则最大值还是之前的值。 
class Solution {
    public int maxProfit(int[] prices) {
        int mcur = 0,min = Integer.MAX_VALUE;
        for (int price : prices) {
            if (min == Integer.MAX_VALUE) {
//                mcur = price - min;
            }else {
                mcur = Math.max(price - min,mcur);
            }
            min = Math.min(price,min);
        }

        return Math.max(mcur, 0);
    }
}

来源:

转载地址:http://gxqef.baihongyu.com/

你可能感兴趣的文章
Leetcode Go 《精选TOP面试题》20200628 69.x的平方根
查看>>
Leetcode C++ 剑指 Offer 09. 用两个栈实现队列
查看>>
Leetcode C++《每日一题》20200707 112. 路径总和
查看>>
云原生 第十一章 应用健康
查看>>
Leetcode C++ 《第202场周赛》
查看>>
云原生 第十二章 可观测性:监控与日志
查看>>
Leetcode C++ 《第203场周赛》
查看>>
云原生 第十三章 Kubernetes网络概念及策略控制
查看>>
《redis设计与实现》 第一部分:数据结构与对象 || 读书笔记
查看>>
《redis设计与实现》 第二部分(第9-11章):单机数据库的实现
查看>>
算法工程师 面经2019年5月
查看>>
搜索架构师 一面面经2019年6月
查看>>
稻草人手记
查看>>
第一次kaggle比赛 回顾篇
查看>>
leetcode 50. Pow(x, n)
查看>>
leetcode 130. Surrounded Regions
查看>>
【托业】【全真题库】TEST2-语法题
查看>>
博客文格式优化
查看>>
【托业】【新托业全真模拟】疑难语法题知识点总结(01~05)
查看>>
【SQL】group by 和order by 的区别。
查看>>