买卖股票的最佳时机系列

news2024/11/28 6:44:09

 

//方法一
class Solution {
public:
    int dp[100005];
    int maxProfit(vector<int>& prices) {
        //dp[i]表示前i天买入卖出的获取的最大利润
        //min_val表示前i-1天买入的最小值;
        dp[0]=0;
        int min_val=prices[0];
        for(int i=1;i<prices.size();i++){
            dp[i]=max(dp[i-1],prices[i]-min_val);
            if(prices[i]<min_val)
            {
                min_val=prices[i];
            }
        }
        int n=prices.size();
        return max(0,dp[n-1]);
    }
};

//方法二

class Solution {
public:
   
    int dp[100005][2]; 
    int maxProfit(vector<int>& prices) {
        //dp[i][0]表示前i天买入股票的最大值;
        //dp[i][1]表示前i天不持有股票的最大值
          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]);
                 dp[i][1]=max(dp[i-1][1],dp[i-1][0]+prices[i]);
          }
          return dp[prices.size()-1][1];
    }
};

 

class Solution {
public:
   
    int dp[100005][2]; 
    int maxProfit(vector<int>& prices) {
        //dp[i][0]表示第i天持有股票的最大值;
        //dp[i][1]表示第i天不持有股票的最大值
          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]);
                 dp[i][1]=max(dp[i-1][1],dp[i-1][0]+prices[i]);
          }
          return dp[prices.size()-1][1];
    }
};

 

class Solution {
public:
    int dp[100005][4];
    int maxProfit(vector<int>& prices) {
    //dp[i][0]表示在第i天持有第一支股票的最大值;
     //dp[i][1]表示在第i天不持有股票的最大值;
      //dp[i][2]表示在第i天持有第二支股票的最大值;
        //dp[i][3]表示在第i天不持有股票的最大值;
      dp[0][0]=-prices[0];
      dp[0][1]=0;
      dp[0][2]=-prices[0];//注意初始值
      dp[0][3]=0;
      for(int i=1;i<prices.size();i++){
          dp[i][0]=max(dp[i-1][0],-prices[i]);
          dp[i][1]=max(dp[i-1][1],dp[i-1][0]+prices[i]);
          dp[i][2]=max(dp[i-1][2],dp[i-1][1]-prices[i]);
          dp[i][3]=max(dp[i-1][3],dp[i-1][2]+prices[i]);
      }
      int n=prices.size();
      return max(0,max(dp[n-1][1],dp[n-1][3]));

    }
};

 

class Solution {
public:
    int dp[1005][205];
    int maxProfit(int k, vector<int>& prices) {
        //dp[i][j*2];第j次持有股票的最大金额
        //dp[i][j*2+1];第j次不持有股票的最大金额
       for(int i=0;i<k;i++)
       {
           dp[0][i*2]=-prices[0];
           dp[0][i*2+1]=0;
       }
       for(int i=1;i<prices.size();i++){
           for(int j=0;j<k;j++)
           {
               if(j==0)
               {
                    dp[i][j*2]=max(dp[i-1][j*2],-prices[i]);
                    dp[i][j*2+1]=max(dp[i-1][j*2+1],dp[i-1][j*2]+prices[i]);
               }else{
                    dp[i][j*2]=max(dp[i-1][j*2],dp[i][j*2-1]-prices[i]);
                    dp[i][j*2+1]=max(dp[i-1][j*2+1],dp[i-1][j*2]+prices[i]);
               }
              
           }
       }
       int n=prices.size()-1;
       int res=0;
       for(int i=0;i<k;i++)
       {
           res=max(dp[n][i*2+1],res);
       }
       return res;
    }
};

 

class Solution {
public:
    int dp[5005][4];
    int maxProfit(vector<int>& prices) {
        //dp[i][0]//持有股票
        //dp[i][1]//保持卖出股票
        //dp[i][2]//卖出股票;
        //dp[i][3]//冷冻期
        dp[0][0]=-prices[0];
        dp[0][1]=0;
        dp[0][2]=0;
        dp[0][3]=0;
        for(int i=1;i<prices.size();i++){
            dp[i][0]=max(dp[i-1][0],max(dp[i-1][3]-prices[i],dp[i-1][1]-prices[i]));
            dp[i][1]=max(dp[i-1][1],dp[i-1][3]);
            dp[i][2]=dp[i-1][0]+prices[i];
            dp[i][3]=dp[i-1][2];
        }
        int res=0;
        int n=prices.size()-1;
        for(int i=0;i<4;i++)
        {
            res=max(res,dp[n][i]);
        }
        return res;
    }
};

 

class Solution {
public:
    int dp[50005][2];
    int maxProfit(vector<int>& prices, int fee) {
        //dp[i][0]持有股票的最大值
        //dp[i][1]//不持有股票的最大值
            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]-fee);
            }    
            int n=prices.size()-1;
            int res=0;
            res=max(res,max(dp[n][0],dp[n][1]));
            return res;
        }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/793456.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

7.26 作业

1. 完善登录界面 main.c #include "widget.h" #include "second.h" #include <QApplication>int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();Second s;QObject::connect(&w,&Widget::to_second,&s,…

利用mysqldump实现分库分表备份的shell脚本

一、信息摘要 linux版本&#xff1a;CentOS 7.9 mysql版本&#xff1a;MySQL 5.7.36 脚本实现功能&#xff1a;利用mysqldump工具实现对mysql中的数据库分库备份&#xff0c;和对所备份数据库中的表分表备份 二、shell脚本 #!/bin/bash ######################### #File n…

ROS1ROS2之CmakeList.txt和package.xml用法详解

前言&#xff1a;目前还在学习ROS无人机框架中&#xff0c;&#xff0c;&#xff0c; 更多更新文章详见我的个人博客主页【前往】 文章目录 1. CMakeLists.txt与package.xml的作用2. 生成CMakeLists.txt2.1 ROS12.2 ROS2 3. CMakeLists.txt编写3.1 ROS13.2 ROS2 4. package.xml…

【Linux指令集】---tar指令(超详细)

个人主页&#xff1a;平行线也会相交 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 平行线也会相交 原创 收录于专栏【Linux专栏】&#x1f388; 本专栏旨在分享学习Linux的一点学习心得&#xff0c;欢迎大家在评论区讨论&#x1f48c; 演示环境&#xff1…

常见面试题之设计模式--策略模式

1. 概述 先看下面的图片&#xff0c;我们去旅游选择出行模式有很多种&#xff0c;可以骑自行车、可以坐汽车、可以坐火车、可以坐飞机。 作为一个程序猿&#xff0c;开发需要选择一款开发工具&#xff0c;当然可以进行代码开发的工具有很多&#xff0c;可以选择Idea进行开发&a…

(学习日记)2023.04.30

写在前面&#xff1a; 由于时间的不足与学习的碎片化&#xff0c;写博客变得有些奢侈。 但是对于记录学习&#xff08;忘了以后能快速复习&#xff09;的渴望一天天变得强烈。 既然如此 不如以天为单位&#xff0c;以时间为顺序&#xff0c;仅仅将博客当做一个知识学习的目录&a…

JS基础算法03--俩数之和

最简单 &#xff0c; 最基础的。 如果不会 &#xff0c; 请写会 &#xff0c;请掌握&#xff0c;请让心安定 给定一个数组 nums 和一个目标值 target&#xff0c;在该数组中找出和为目标值的两个数 const nums [1, 2, 3, 4, 5, 6, 7, 8]const target 5function find(nums, t…

Vue.js入门指南:从基础到进阶,掌握现代JavaScript框架的核心概念与高级特性(2W字小白教程)

&#x1f337;&#x1f341; 博主 libin9iOak带您 Go to New World.✨&#x1f341; &#x1f984; 个人主页——libin9iOak的博客&#x1f390; &#x1f433; 《面试题大全》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33…

基于 Python 的性能测试工具 locust (与 LR 的简单对比)

目录 前言&#xff1a; 背景 基础 测试需求 服务器端 LR 中的测试脚本 locust 中的测试脚本 LR 中的测试过程和结果 Locust 中的测试过程和结果 结果比较 总结 前言&#xff1a; Locust 是一种开源的性能测试工具&#xff0c;可以帮助我们快速地进行网站、应用程序…

Linux:入门学习知识及常见指令

文章目录 入门介绍操作系统的概念Linux机器的使用Linux上的指令 对文件知识的补充文件的定义和一些含义文件和目录的存储绝对路径和相对路径 ls指令pwd指令cd指令touch指令mkdir指令rmdir指令rm指令man指令cp指令mv指令cat指令more指令echo指令输出重定向 less指令find指令grep…

【UE5 多人联机教程】05-生成玩家

步骤 1. 新建一个游戏模式基础 命名为“GM_Lobby” 2. 新建一个玩家控制器&#xff0c;命名为“PC_Lobby” 3. 新建一个游戏状态基础 命名为“GS_Lobby” 重新设置游戏模式重载、玩家控制器类、游戏状态类 4. 新建一个控件蓝图&#xff0c;命名为“UMG_Lobby” 打开“UMG_Lobb…

AI数字人为千行百业赋能,具有哪些优势?

AI产业的发展迅速&#xff0c;促使AI数字人产业也迎来了高速发展&#xff0c;数字人凭借愈发逼真的形象&#xff0c;开始在更多的场景、行业中进行赋能&#xff0c;为千行百业注入新的灵魂。 现阶段&#xff0c;数字人理论和技术正在不断成熟&#xff0c;应用范围也在不断扩大&…

opencv-25 图像几何变换04- 重映射-函数 cv2.remap()

什么是重映射&#xff1f; 重映射&#xff08;Remapping&#xff09;是图像处理中的一种操作&#xff0c;用于将图像中的像素从一个位置映射到另一个位置。重映射可以实现图像的平移、旋转、缩放和透视变换等效果。它是一种基于像素级的图像变换技术&#xff0c;可以通过定义映…

为什么需要GP(Global Platform)认证?

TEE之GP(Global Platform)认证汇总 一、为什么需要认证&#xff1f; 二、为什么是GP&#xff1f; 参考&#xff1a; GlobalPlatform Certification - GlobalPlatform

Unity光照相关知识和实践 (烘焙光照,环境光设置,全局光照)

简介 本文将会通过一个简单的场景搭建&#xff0c;介绍如何使用烘焙光照以及相关的注意事项。另外还介绍了Unity内全局光照&#xff08;GI&#xff09;的知识和GI实际在游戏内的表现效果。 Unity关于光照相关的参考文档地址&#xff1a;https://docs.unity.cn/cn/current/Man…

黑客自学笔记(网络安全)

一、黑客是什么 原是指热心于计算机技术&#xff0c;水平高超的电脑专家&#xff0c;尤其是程序设计人员。但后来&#xff0c;黑客一词已被用于泛指那些专门利用电脑网络搞破坏或者恶作剧的家伙。 二、学习黑客技术的原因 其实&#xff0c;网络信息空间安全已经成为海陆空之…

使用goldengate 迁移Oracle到postgresql

环境&#xff1a; --源端&#xff1a; IP&#xff1a;10.0.4.16 hostname&#xff1a;tencent Oracle数据库版本&#xff1a;12.2.0.1.0 ogg for oracle版本&#xff1a;19.1.0.0.4 SID&#xff1a;orcl --目标端&#xff1a; IP&#xff1a;10.0.4.16 hostname&#…

Spring 6【p命名空间和c命名空间】(五)-全面详解(学习总结---从入门到深化)

目录 十、p命名空间和c命名空间 十、p命名空间和c命名空间 老版本的Spring框架XML配置文件是使用DTD的&#xff0c;但是在目前Spring框架中多使用XSD。因为在XSD扩 展支持。这也是为什么Spring框架配置文件由原来的DTD更换成XML Schema&#xff0c;毕竟Spring现在是模块化了&…

java 锁详解

死锁有四个条件 1. 互斥性 某个锁单元只能被某个运算单元占用 2. 不可以剥夺 线程获取某个资源, 这个资源不可以被其他资源剥夺, 只能自己释放, 3. 请求并保持 请求别的资源的同时却保持占有某个资源 4. 形成循环链路 一般锁都有互斥性, 读锁没有互斥性. 一般的锁都不…

视觉系统相关的网站

1.视觉系统设计 视觉系统设计网址&#xff1a;http://www.vision-systems-china.com/emag/emag.asp