• 力扣刷题(122. 买卖股票的最佳时机 II)动规、贪心


    给你一个整数数组 prices ,其中 prices[i] 表示某支股票第 i 天的价格。

    在每一天,你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买,然后在 同一天 出售。

    返回 你能获得的 最大 利润 。

    示例 1:

    输入:prices = [7,1,5,3,6,4]
    输出:7
    解释:在第 2 天(股票价格 = 1)的时候买入,在第 3 天(股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5 - 1 = 4 。
         随后,在第 4 天(股票价格 = 3)的时候买入,在第 5 天(股票价格 = 6)的时候卖出, 这笔交易所能获得利润 = 6 - 3 = 3 。
         总利润为 4 + 3 = 7 。

    思路:动规dp

    首先需要顶一个一个二维数组dp,每天应该是有两种状态,一是当天持有股票,一是当前不持有股票,设不持有股票的利润为first,持有股票的利润为second。

    那么dp[i].first=max(dp[i-1].first,dp[i-1].second+prices[i]),每一天不持有股票的利润就是前一天不持有股票的利润和前一天持有股票然后以今天的价格卖掉的利润中的最大值

    那么dp[i].second=max(dp[i-1].second,dp[i-1].frist-prices[i]),每一天持有股票的最大利润就是前一天持有股票的利润和前一天不持有股票然后今天买入的利润中的最大值。

    当i=0,也就是第一天要特殊处理一下。

    1. class Solution {
    2. public:
    3. int maxProfit(vector<int>& prices) {
    4. int n=prices.size();
    5. //first表示当前不持有股票的最大利润,second表示当前持有股票的最大利润
    6. vectorint,int>> dp(n);
    7. for(int i=0;i
    8. if(i>0){
    9. dp[i].first=max(dp[i-1].first,dp[i-1].second+prices[i]);
    10. dp[i].second=max(dp[i-1].second,dp[i-1].first-prices[i]);
    11. }else{
    12. dp[i].first=0;
    13. dp[i].second=-prices[i];
    14. }
    15. }
    16. return dp[n-1].first;
    17. }
    18. };

    思路:贪心

    这一题要找的其实就是所有prices[i+1]>prices[i]的不相交区间的和,因此只要每天都判断下一天是否满足prices[i+1]-prices[i]大于0即可。大于0说明今天买入第二天卖出有利润,否则说明只能当天买入当天卖出。

    1. class Solution {
    2. public:
    3. int maxProfit(vector<int>& prices) {
    4. int ans=0,n=prices.size();
    5. for(int i=0;i-1;++i){
    6. int temp=prices[i+1]-prices[i];
    7. ans+=max(0,temp);
    8. }
    9. return ans;
    10. }
    11. };

  • 相关阅读:
    Python逆向爬虫之scrapy框架,非常详细
    服务器大请求体问题定位
    多叉树+图实现简单业务流程
    【笔试】2022/9/4 网易互联网开发岗满分
    看完这篇文章你就可以告诉领导你精通Zookeeper了
    关键词搜索排行榜-精准找到行业流量关键词
    【JavaScript】判断是否为对象
    React fiber分片的理解和剖析
    中科驭数DPU技术开放日秀“肌肉”:云原生网络、RDMA、安全加速、低延时网络等方案组团亮相
    Centos7通过yum安装docker
  • 原文地址:https://blog.csdn.net/yanzhe1/article/details/125886661