首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >买卖股票的最佳时机(C++)

买卖股票的最佳时机(C++)

作者头像
GeekLiHua
发布2025-01-21 11:07:39
发布2025-01-21 11:07:39
11800
代码可运行
举报
文章被收录于专栏:JavaJava
运行总次数:0
代码可运行
买卖股票的最佳时机

给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。

你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。

返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0

示例 1:

代码语言:javascript
代码运行次数:0
运行
复制
输入: [7,1,5,3,6,4]
输出: 5
解释: 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。
     注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票。

示例 2:

代码语言:javascript
代码运行次数:0
运行
复制
输入: prices = [7,6,4,3,1]
输出: 0
解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。

提示:

  • 1 <= prices.length <= 105
  • 0 <= prices[i] <= 104

我的代码:

代码语言:javascript
代码运行次数:0
运行
复制
class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int INF = 1000000;
        int minp = INF, maxp = 0;
        // 这个题的本质就是从前往后看 找到当前已知的最下的数字, 然后用未来最大的数字减去他
        for (auto price: prices)
        {
            maxp = max(maxp, price - minp);
            minp = min(price, minp);
        }
        return maxp;
    }
};

对应我的掘金文章:https://juejin.cn/post/7147300172584714277

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-10-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 买卖股票的最佳时机
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档