leetcode日记(106)买卖股票的最佳时机Ⅲ

算是困难题里比较容易写的题目了,只是思路可能有些新奇(好吧后来发现只有我的思路如此新奇)。

我的做法是根据先前的经验,先从前往后遍历一次,记录每遍历到一个位置的最大收益,接着从后往前遍历,同样找最大收益,看取哪个相加收益最大就行。

这种做法最大缺点就是只有只能买两次能用,要是能买三次四次就用不了了。

cpp 复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int forward[100001];
        int maxx=0;
        int minn=100000;
        for(int i=0;i<prices.size();i++){
            maxx=max(prices[i]-minn,maxx);
            minn=min(prices[i],minn);
            forward[i]=maxx;
        }
        int result;
        maxx=0;minn=100000;
        for(int i=prices.size()-1;i>=0;i--){
            minn=min(prices[i]-maxx,minn);
            maxx=max(prices[i],maxx);
            result=max(result,forward[i]-minn);
        }
        return result;
    }
};

答案用的是动态规划,用时和消耗空间差不多,也更容易理解一些,非常好解析:

cpp 复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int buy1=-prices[0],sell1=0,buy2=-prices[0],sell2=0;
        for(int i=1;i<prices.size();i++){
            buy1=max(buy1,-prices[i]);
            sell1=max(sell1,prices[i]+buy1);
            buy2=max(buy2,sell1-prices[i]);
            sell2=max(sell2,prices[i]+buy2);
        }
        return sell2;
    }
};
相关推荐
To_OC8 小时前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安13 小时前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者15 小时前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
kisshyshy21 小时前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC1 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635072 天前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC2 天前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥2 天前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程