【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
代码少不是最优!!!

posted @ 2021-12-26 16:55  jucw  阅读(78)  评论(0编辑  收藏  举报