最佳买股票的时机------题解报告

题目:

暴力双循环会时间超限

一次循环,不断更新min和sum值

时间复杂度为O(n),空间复杂度为O(1)

写完之后看了一眼题解,发现没有更好的方法

java 复制代码
 public int maxProfit(int[] prices) {
        int sum =0,min=prices[0];
        for(int i=1;i <prices.length;i++)
        {
            min=Math.min(min,prices[i]);
            if(prices[i]-min>sum)
            {
                sum=prices[i]-min;
            }
        }
        return sum;
    }
相关推荐
月明长歌2 分钟前
【码道初阶-Hot100】LeetCode 560. 和为 K 的子数组:从前缀和到哈希计数,彻底讲透为什么“统计前缀和”就等价于统计子数组个数
算法·leetcode·哈希算法
yuanlaile4 分钟前
2026后端趋势:Java 老了?Go 才是未来?
java·后端·golang·go与java·后端学什么
tankeven8 分钟前
HJ134 1or0
c++·算法
keep intensify13 分钟前
寻找重复数
数据结构·算法·leetcode
春日见17 分钟前
Matlab快速入门 基础语法教学
java·开发语言·驱动开发·matlab·docker·计算机外设
dgfhf17 分钟前
高性能计算资源调度
开发语言·c++·算法
浩瀚之水_csdn26 分钟前
++ Lambda 表达式详解
java·jvm·windows
x_xbx29 分钟前
LeetCode:19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
weixin_3077791333 分钟前
OpenClaw-CN 安全增强方案:从理念到落地的全面剖析
开发语言·人工智能·算法·安全·语言模型
CoovallyAIHub34 分钟前
Agency-Agents(52k+ Stars):140+ 个角色模板,让 AI 编程助手变成一支专业团队
前端·算法·编程语言