LeetCode 面试经典150题 121.买卖股票的最佳时机

题目

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

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

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

思路

代码

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        int ans = 0;
        int minPrice = prices[0];
        for (int p : prices) {
            ans = Math.max(ans, p - minPrice);
            minPrice = Math.min(minPrice, p);
        }
        return ans;
    }
}

性能:时间复杂度O(n) 空间复杂度O(1)

相关推荐
寂静山林7 分钟前
UVa 1030 Image Is Everything
算法
AI柠檬13 分钟前
几种排序算法的实现和性能比较
数据结构·算法·c#·排序算法
weixin_4296302642 分钟前
第6章 支持向量机
算法·机器学习·支持向量机
SweetCode42 分钟前
C++ 实现大数加法
开发语言·c++·算法
王哈哈^_^44 分钟前
【数据集】【YOLO】【目标检测】共享单车数据集,共享单车识别数据集 3596 张,YOLO自行车识别算法实战训推教程。
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
CodeWizard~2 小时前
AtCoder Beginner Contest 430赛后补题
c++·算法·图论
大大dxy大大2 小时前
机器学习-KNN算法示例
人工智能·算法·机器学习
007php0072 小时前
某游戏互联网大厂Java面试深度解析:Java基础与性能优化(一)
java·数据库·面试·职场和发展·性能优化·golang·php
关于不上作者榜就原神启动那件事3 小时前
模拟算法乒乓球
开发语言·c++·算法
Bug退退退1233 小时前
ArrayList 与 LinkedList 的区别
java·数据结构·算法