leetcode hot100刷题日记——19.买卖股票的最佳时机

解答:

cpp 复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {
        //思路:买股票的时候希望自己在最低点买入,最高点卖出,但是有卖出点要在买入点后面的时间限制
        //而遍历,自然而然有"时间限制"
        //所以在一次遍历过程中,我们把每天都看成考虑要不要卖出去,假设自己之前是在最低点买入
        //更新最低价格
        //检查当前能不能得到最高利润,即maxx=max(maxx,prices[i]-minn);
        int minn=1e9;
        int maxx=0;
        int n=prices.size();
        if(n==1){
                return 0;
        }
        for(int i=0;i<n;i++){
        		minn=min(minn,prices[i]);
                maxx=max(maxx,prices[i]-minn);
        }
        return maxx;
    }
};

时间复杂度:O(N)

空间复杂度:O(1)

看到题解说这也是一种动态规划的思想,我们来捋一下:

对于第i天,

  • 我们如果在前i-1天已经完成了一轮买卖操作,则第i天不能做任何操作,问题转化为dp[i-1]
  • 如果我们在前i-1天只是做了买入,在第i天卖出,那么在第0到第i天,进行一轮买卖操作,在这种情况下,卖出的价格一定是prices[i],那么买入价格一定是前i-1天中的最小值,即minn=min(prices[0],......prices[i-1]),收益就是prices[i]-minn
    而要使收益最大,dp[i]=max(dp[i-1],prices[i]-minn)
相关推荐
Q741_14719 分钟前
每日一题 力扣 3655. 区间乘法查询后的异或 II 模拟 分治 乘法差分法 快速幂 C++ 题解
c++·算法·leetcode·模拟·快速幂·分治·差分法
The_Ticker20 分钟前
印度股票实时行情API(低成本方案)
python·websocket·算法·金融·区块链
夏乌_Wx24 分钟前
剑指offer | 2.4数据结构相关题目
数据结构·c++·算法·剑指offer·c/c++
米啦啦.26 分钟前
C+类的友元与静态成员函数,类模板
c++·友元·类模板
超绝振刀怪31 分钟前
【C++可变模板参数】
开发语言·c++·可变模板参数
AI成长日志1 小时前
【笔面试算法学习专栏】哈希表基础:两数之和与字母异位词分组
学习·算法·面试
minji...1 小时前
Linux 线程同步与互斥(二) 线程同步,条件变量,pthread_cond_init/wait/signal/broadcast
linux·运维·开发语言·jvm·数据结构·c++
梓䈑1 小时前
高性能 C++ 日志实战:spdlog 核心架构解析与最佳实践指南
c++·架构
abant21 小时前
leetcode 239 单调队列 需要一些记忆
算法·leetcode·职场和发展
漫霂1 小时前
二叉树的统一迭代遍历
java·算法