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;
    }
};
相关推荐
金智维科技官方9 小时前
常见的大模型分类
人工智能·算法·ai·语言模型·数据挖掘
yzzzzzzzzzzzzzzzzz9 小时前
leetcode热题——有效的括号
算法·
崎岖Qiu10 小时前
leetcode1343:大小为K的子数组(定长滑动窗口)
java·算法·leetcode·力扣·滑动窗口
Shun_Tianyou11 小时前
Python Day25 进程与网络编程
开发语言·网络·数据结构·python·算法
Giser探索家11 小时前
什么是2米分辨率卫星影像数据?
大数据·人工智能·数码相机·算法·分类·云计算
jz_ddk13 小时前
[科普] AI加速器架构全景图:从GPU到光计算的算力革命
人工智能·学习·算法·架构
曦月逸霜13 小时前
内部排序算法总结(考研向)
考研·算法·排序算法
仪器科学与传感技术博士13 小时前
Matplotlib库:Python数据可视化的基石,发现它的美
开发语言·人工智能·python·算法·信息可视化·matplotlib·图表可视化
BOB_BOB_BOB_14 小时前
【ee类保研面试】其他类---计算机网络
计算机网络·面试·职场和发展·保研
success15 小时前
【爆刷力扣-二叉树】层次遍历
算法