Python教程

【LeetCode】NO.122 买卖股票的最佳时机 II (C++ & Python) [贪心算法]

本文主要是介绍【LeetCode】NO.122 买卖股票的最佳时机 II (C++ & Python) [贪心算法],对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

题目[中等]

给定一个数组 prices ,其中 prices[i] 是一支给定股票第 i 天的价格。

设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。

注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock-ii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

思路

  1. 只要求出每天利润是正的就行
  • p[3]-p[0] = p[3]-p[2]+p[2]-p[2]+p[1]-p[0];

代码

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

class Solution:
    def maxProfit(self, prices: List[int]) -> int:
        total = 0
        for i in range(1, len(prices)):
            dif = prices[i]-prices[i-1]
            if dif>0:
                total += dif
        return total

结果

image
代码少不是最优!!!

这篇关于【LeetCode】NO.122 买卖股票的最佳时机 II (C++ & Python) [贪心算法]的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!