算法训练营第四十九天||● 121. 买卖股票的最佳时机 ● 122.买卖股票的最佳时机II

● 121. 买卖股票的最佳时机

暴力和贪心都可以解决

主要讲解动态规划

dp数组:我们把dp数组定义为一个二维的vector容器

dp[i][0]表示第i天持有股票手中的金额:它可以是当天买入的也可以是之前买入的

dp[i][1]表示第i天不持有股票手中的金额:可以是当天卖出的也可以是之前卖出的

初始化:

dp[0][0]:第0天就持有股票,说明它第0天买入了股票 此时手中现金为 -peices[0]

dp[0][1]:第0天不持有股票,说明它既没有买入也没有卖出 手中现金为0。

遍历顺序:从前往后 后一天由前一天推导出。

递推公式:

dp[i][0]=max(dp[i-1][0],prices[i])

dp[i][1]=max(dp[i-1][1],dp[i-1][0]+prices[i]);

最后返回值:就是最后一天不持有股票的手中的最大现金

复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {
        vector<vector<int>> dp(prices.size()+1,vector<int>{0,0});
        dp[0][0] = -prices[0];
        dp[0][1] = 0;
        for(int i = 1;i<prices.size();i++){
            dp[i][0] = max(dp[i-1][0],-prices[i]);//第i天不持有股票的最大金额
            dp[i][1] = max(dp[i-1][1],prices[i]+dp[i-1][0]);//第i天持有股票的最大金额
        }
        return max(dp[prices.size()-1][0],dp[prices.size()-1][1]);
    }
};

● 122.买卖股票的最佳时机II

与上一题的唯一区别就是 股票可以买卖多次,递推公式的时候略微有点变化

dp[i][0] = max(dp[i-1][0],dp[i-1][1]-prices[i]);

是由前一天持有股票,或者前一天不持有股票今天买入的最大值组成 ,此时前一天不持有股票手中现金不再是0而是dp[i-1][1]

dp[i][1]与上一道题完全相同。

复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {
        vector<vector<int>> dp(prices.size()+1,vector<int>{0,0});
        dp[0][0] = -prices[0];
        dp[0][1] = 0;
        for(int i = 1;i<prices.size();i++){
            dp[i][0] = max(dp[i-1][0],dp[i-1][1]-prices[i]);
            dp[i][1] = max(dp[i-1][1],dp[i-1][0]+prices[i]);
        }
        return dp[prices.size()-1][1];
    }
};
相关推荐
2301_822703201 天前
Flutter 框架跨平台鸿蒙开发 - 创意声音合成器应用
算法·flutter·华为·harmonyos·鸿蒙
cmpxr_1 天前
【C】数组名、函数名的特殊
c语言·算法
KAU的云实验台1 天前
【算法精解】AIR期刊算法IAGWO:引入速度概念与逆多元二次权重,可应对高维/工程问题(附Matlab源码)
开发语言·算法·matlab
会编程的土豆1 天前
【数据结构与算法】再次全面了解LCS底层
开发语言·数据结构·c++·算法
大熊背1 天前
如何利用Lv值实现三级降帧
算法·自动曝光·lv·isppipeline
大尚来也1 天前
驾驭并发:.NET多线程编程的挑战与破局之道
java·前端·算法
向阳而生,一路生花1 天前
深入浅出 JDK7 HashMap 源码分析
算法·哈希算法
君义_noip1 天前
信息学奥赛一本通 4150:【GESP2509七级】⾦币收集 | 洛谷 P14078 [GESP202509 七级] 金币收集
c++·算法·gesp·信息学奥赛·csp-s
摸个小yu1 天前
【力扣LeetCode热题h100】链表、二叉树
算法·leetcode·链表
汀、人工智能1 天前
[特殊字符] 第93课:太平洋大西洋水流问题
数据结构·算法·数据库架构·图论·bfs·太平洋大西洋水流问题