股票模拟交易_复杂状态机

股票模拟交易_复杂状态机给定一个长度为 N 的数组,数组中的第 i 个数字表示一个给定股票在第 i 天的价格。设计一个算法计算出最大利润。在满足以下约束条件下,你可以尽可能地完成更多的交易(多次买卖一支股票):你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。卖出股票后,你无法在第二天买入股票 (即冷冻期为 1 天)。输入格式第一行包含整数 N,表示数组长度。第二行包含 N 个不超过 10000 的正整数,表示完整的数组。输出格式输出一个整数,表示最大利润。数据范围1≤N≤105输入样例:51

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

给定一个长度为 N 的数组,数组中的第 i 个数字表示一个给定股票在第 i 天的价格。

设计一个算法计算出最大利润。在满足以下约束条件下,你可以尽可能地完成更多的交易(多次买卖一支股票):

你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。
卖出股票后,你无法在第二天买入股票 (即冷冻期为 1 天)。
输入格式
第一行包含整数 N,表示数组长度。

第二行包含 N 个不超过 10000 的正整数,表示完整的数组。

输出格式
输出一个整数,表示最大利润。

数据范围
1≤N≤105

输入样例:
5
1 2 3 0 2
输出样例:
3

样例解释
对应的交易状态为: [买入, 卖出, 冷冻期, 买入, 卖出],第一笔交易可得利润 2-1 = 1,第二笔交易可得利润 2-0 = 在这里插入代码片2,共得利润 1+2 = 3。
题解
动态规划
f[0][0]代表第一天无货,f[0][1]代表第二、三、四…天无货,f[0][2]代表有货

#include<bits/stdc++.h>
using namespace std;
const int N = 1e5+100;
int f[N][3];
const int INF = 0x3f3f3f3f;
int main(){ 
   
    int n,x;
    cin>>n;
    //f[0][0]代表第一天无货,f[0][1]代表第二、三、四...天无货,f[0][2]代表有货
    f[0][0] = f[0][1] = 0;
    f[0][2] = -INF;
    for(int i = 1;i <= n;i ++){ 
   
        cin>>x;
        f[i][0] = f[i - 1][2] + x;
        f[i][1] = max(f[i - 1][1],f[i - 1][0]);
        f[i][2] = max(f[i - 1][2],f[i - 1][1] - x);
    }
    cout<<max(f[n][1],f[n][0])<<endl;
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168861.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月9日 上午10:00
下一篇 2022年8月9日 上午10:00


相关推荐

  • Idea中建多层级包时出现的问题

    Idea中建多层级包时出现的问题刚开始使用idea时发现不会分包。假如我想在com下面分别建Dao、pojo、service包等,会出现每次在上一个包里面建包,并不会使Dao、pojo、service包平级。解决方法:方法一:            1)先在java包下建名为com包,     2)鼠标点击com的上一级包(这里就是java包),然后新建包为com.Dao包。这里会出现不用着急,因为你只有一个包。再继续点击com…

    2022年6月13日
    37
  • Mybatis 动态SQL

    Mybatis 动态SQLMybatis动态SQL一.动态SQL数组array使用foreach标签<!–mybatis的集合操作知识点:如果遇到集合参数传递,需要将集合遍历标签:foreach循环遍历集合标签属性说明:1.collection表示遍历的集合类型1.1数组关键字array1.2List集合关键字lis

    2022年6月23日
    30
  • Idea激活码最新教程2020.3.1版本,永久有效激活码,亲测可用,记得收藏

    Idea激活码最新教程2020.3.1版本,永久有效激活码,亲测可用,记得收藏Idea 激活码教程永久有效 2020 3 1 激活码教程 Windows 版永久激活 持续更新 Idea 激活码 2020 3 1 成功激活

    2025年5月22日
    4
  • CSS媒体查询(@media)全面解析

    CSS媒体查询(@media)全面解析随着移动设备的快速普及 用户不再只是通过传统的电脑系来浏览 Web 内容 越来越多的用户开始使用各种尺寸的智能手机 平板电脑或者其它设备来浏览 Web 内容 为了确保使用不同设备的用户都能拥有不错的体验就需要用到媒体查询 媒体查询是 CSS 样式表最重要的功能之一 所谓媒体查询指的就是根据不同的媒体类型 设备类型 和条件来区分各种设备 例如 电脑 手机 平板电脑 盲文设备等 并为它们分别定义不同的 CSS 样式 媒体查询能让 CSS 可以更精确的作用于不同的设备或同一设备的不同条件 让所有用户都能得到很

    2026年3月19日
    3
  • 如何在pycharm中使用git

    如何在pycharm中使用git工具列表 git 2 11 0 64 bitpycharm20 3 41 安装 git 工具 2 去 github 官网注册账号 github3 进入 pycharm file gt settings gt VersionContr gt github 进行远程 github 设置 4 VersionContr gt git 进行本地 git 配置 5 点击 o

    2026年3月27日
    2
  • FFmpeg从入门到精通笔记之二

    FFmpeg从入门到精通笔记之二FFmpeg中常用的工具主要是ffmpeg、ffprobe、ffplay,它们分别用作多媒体的编解码工具、内容分析工具和播放器。ffmpeg常用命令ffmpeg的封装转换。ffmpeg的封装转换(转封装)功能包含在AVFormat模块中,通过libavformat库进行Mux和Demux操作.  *多媒体文件的格式有很多种,这些格式中的很多参数在Mux与Demux的操作参数中是公用的,…

    2022年6月26日
    30

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号