LeetCode如何解决买卖股票的最佳时机问题

发布时间:2022-01-19 10:15:33 作者:小新
来源:亿速云 阅读:162

这篇文章给大家分享的是有关LeetCode如何解决买卖股票的最佳时机问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

一、题目描述

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

示例 1:
输入:[7,1,5,3,6,4]输出:5解释:在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。
     注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票。
     
示例 2:
输入:prices = [7,6,4,3,1]输出:0解释:在这种情况下, 没有交易完成, 所以最大利润为 0。

提示:1 <= prices.length <= 10^50 <= prices[i] <= 10^4

二、解题思路

(1) 暴力求解法

解题思路:

这种方法很简单,对于本题,需要找出给定数组中两个数字之间的最大差值(即,最大利润)。此外,第二个数字(卖出价格)必须大于第一个数字(买入价格)。形式上,对于每组 i 和 j(其中 j > i),我们需要找出 max(prices[j]−prices[i])。

C++代码实现如下:

class Solution {
   
   
   public:int maxProfit(vector<int>& prices) {
   
   
   int max_profit=0;for(int i=0; i<prices.size(); ++i){
   
   
   for(int j=i+1; j<prices.size(); ++j){
   
   
   max_profit = max(prices[j]-prices[i],max_profit);}}return max_profit;}};

复杂度分析:

采用这种方法,时间复杂度是 O ( n 2 ) O(n^2) O(n2),所以当数组prices长度取上限 1 0 5 10^5 105时,这种方法肯定会超时,通过不了测试,如下图所示:
LeetCode如何解决买卖股票的最佳时机问题

(2) 一次遍历

解题思路:

使用嵌套循环会超时,那么我们就来考虑一次遍历的方法。我们可以换一种思路来思考这个问题:先不要同时去考虑买入和卖出的时间。假如我们今天(第i天)要卖出,那么在什么时间(选择前i-1天都可以)买入最合适呢?
很明显,在前i-1天中,股票最低的那天买入,收益最大。

C++代码实现如下:

class Solution {
   
   
   public:int maxProfit(vector<int>& prices) {
   
   
   int min_price = prices[0];int max_profit = 0;for(int i=1; i<prices.size(); ++i){
   
   
   min_price = min(prices[i], min_price);max_profit = max(max_profit, prices[i]-min_price);}return max_profit;}};

测试结果:
LeetCode如何解决买卖股票的最佳时机问题
复杂度分析:

感谢各位的阅读!关于“LeetCode如何解决买卖股票的最佳时机问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

推荐阅读:
  1. python买卖股票的最佳时机(基于贪心/蛮力算法)
  2. java计算买卖股票的示例分析

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

leetcode

上一篇:SpringBoot整合MybatisPlus如何实现字符串对比

下一篇:html5中有哪些常用框架

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》