LeetCode算法题-Best Time to Buy and Sell Stock

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> LeetCode算法题-Best Time to Buy and Sell Stock

这是悦乐书的第172次更新,第174篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第31题(顺位题号是121)。假设有一个数组,其中第i个元素是第i天给定股票的价格。如果只被允许完成最多一笔交易(即买入并卖出一股股票),请设计算法以找到最大利润。请注意,在购买之前不能出售股票。例如:

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

说明:在第2天买入(价格= 1)并在第5天卖出(价格= 6),利润= 6-1 = 5。不是7-1 = 6,因为售价需要大于购买价格。

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

说明:在这种情况下,不进行任何交易,即最大利润= 0。

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 解题

特殊情况一:当传入的数组为null时,直接返回0。

特殊情况二:当传入的数组不为null,但是其内只有0个或者1个元素时,无法支持买入并卖出操作,直接返回0。

正常情况:要想股票获利,需要满足低买高卖的条件,否则不获利甚至亏损。先将第1天的价格单独拿出来,接着开始遍历数组(从第二个元素开始遍历),如果第二天的价格高于第一天的价格,此时的最大利润是第二天的价格减去第一天的价格与最大利润初始值之间的最大值,否则买入价格就应该换成第二天的价格,依次向后循环,直到比较完所有的价格。最后,如果最大利润大于0,此时最大利润就是其本身,否则最大利润为0。


public int maxProfit(int[] prices) {
    if (prices == null || prices.length = 1) {
        return 0;
    }
    int maxProfit = Integer.MIN_VALUE;
    int buyPrice = prices[0];
    for (int i=1; i  prices.length; i++) {
        if (prices[i]  buyPrice) {
            maxProfit = Math.max(maxProfit, prices[i]-buyPrice);
        } else {
            buyPrice = prices[i];
        }
    }
    if (maxProfit  0) {
        return maxProfit;
    }
    return 0;
}

对于上面的最大利润的初始值,也可以设为0,最后直接返回最大利润即可,就无需再加多一步判断了。

03 小结

此题的解法只用了一层循环,因此时间复杂度是**O(n);此题只创建了两个变量,因此空间复杂度是O(1)**。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode算法题-Best Time to Buy and Sell Stock

可能你还想看:

原文始发于微信公众号( 悦乐书 ):

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> LeetCode算法题-Best Time to Buy and Sell Stock


 上一篇
LeetCode算法题-Single Number(Java实现) LeetCode算法题-Single Number(Java实现)
这是悦乐书的第175次更新,第177篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第34题(顺位题号是136)。给定一个非空的整数数组,除了一个元素外,每个元素都会出现两次。 找到那个只出现了一次的元素。例如:
2021-04-05
下一篇 
LeetCode算法题-Valid Palindrome(Java实现) LeetCode算法题-Valid Palindrome(Java实现)
这是悦乐书的第174次更新,第176篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第33题(顺位题号是125)。给定一个字符串,确定它是否是回文,只考虑字母数字字符并忽略大小写。空字符串是有效回文。例如:
2021-04-05