力扣第40天----第121题、第122题

力扣第40天----第121题、第122题

文章目录

一、第121题--买卖股票的最佳时机

​ 分2种情况考虑,根据持有股票、不持有股票这2种情况,完成递推公式。另外,这里要求只买卖一次,所以买入的前一个状态一定是手里现金为0。

c++ 复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {    //0表示不持有, 1表示持有
        vector<vector<int>> dp(2, vector<int>(prices.size(), 0));
        dp[0][0] = 0;
        dp[1][0] = -prices[0];
        for(int i =1; i<prices.size(); ++i){
            dp[0][i] = max(dp[0][i-1], dp[1][i-1] + prices[i]);
            dp[1][i] = max( - prices[i], dp[1][i-1] );  //这里控制,只买卖一次。如果是别的值(不是0),就是买卖多次。
        }
        return dp[0][prices.size() - 1];
    }
};

二、第122题--买卖股票的最佳时机II

​ 跟上一题,基本一样。可以买卖多次,那么买入的前一个状态,手里可以有现金,要根据前一个状态手里现金数,再做处理。

c++ 复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {    //0表示不持有, 1表示持有
        vector<vector<int>> dp(2, vector<int>(prices.size(), 0));
        dp[0][0] = 0;
        dp[1][0] = -prices[0];
        for(int i =1; i<prices.size(); ++i){
            dp[0][i] = max(dp[0][i-1], dp[1][i-1] + prices[i]);
            dp[1][i] = max(dp[0][i-1] - prices[i], dp[1][i-1] );
        }
        return dp[0][prices.size() - 1];
    }
};
相关推荐
Ln5x9qZC21 分钟前
尾递归与Continuation
算法
一路向北he1 分钟前
esp32库依赖
c语言·c++·算法
老四啊laosi2 分钟前
[双指针] 6. 查找总价为目标值的两个商品
算法·力扣·总价为目标值得两商品
人间寥寥情难诉18 分钟前
LRU算法本地实现
java·算法·spring
moonsea020320 分钟前
2026.4.2
开发语言·c++·算法
cpp_250127 分钟前
P10376 [GESP202403 六级] 游戏
c++·算法·动态规划·题解·洛谷·gesp六级
智者知已应修善业29 分钟前
【51单片机4个IO实现16按键可扩展独立按键64矩阵驱动显示矩阵原值】2023-5-8
c++·经验分享·笔记·算法·51单片机
hui-梦苑29 分钟前
[GROMACS]模拟数据分析前轨迹文件生成-轨迹预处理
人工智能·算法·数据分析
蒸汽求职32 分钟前
低延迟系统优化:针对金融 IT 与高频交易,如何从 CPU 缓存行(Cache Line)对齐展现硬核工程底蕴?
sql·算法·缓存·面试·职场和发展·金融·架构
南山乐只34 分钟前
Java并发工具:synchronized演进,从JDK 1.6 锁升级到 JDK 24 重构
java·开发语言·后端·职场和发展