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;
    }
};
相关推荐
圣保罗的大教堂44 分钟前
《算法笔记》9.3小节——数据结构专题(2)->树的遍历 问题 A: 树查找
算法
自信的小螺丝钉2 小时前
Leetcode 1277. 统计全为 1 的正方形子矩阵 动态规划
leetcode·矩阵·动态规划
乌云暮年3 小时前
算法刷题整理合集(四)
java·开发语言·算法·dfs·bfs
Luo_LA4 小时前
【排序算法对比】快速排序、归并排序、堆排序
java·算法·排序算法
AI技术控4 小时前
机器学习算法实战——天气数据分析(主页有源码)
算法·机器学习·数据分析
oioihoii4 小时前
C++20 中的同步输出流:`std::basic_osyncstream` 深入解析与应用实践
c++·算法·c++20
猪猪成4 小时前
【图论】FLOYD弗洛伊德算法-最短路径
学习·算法·图论
HR Zhou4 小时前
群体智能优化算法-粒子群优化算法(Particle Swarm Optimization, PSO,含Matlab源代码)
算法·matlab·优化·智能优化算法
SsummerC4 小时前
【leetcode100】搜索二维矩阵
python·线性代数·leetcode·矩阵
SylviaW084 小时前
python-leetcode 48.括号生成
算法·leetcode·职场和发展