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

题目:

暴力双循环会时间超限

一次循环,不断更新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;
    }
相关推荐
a努力。4 小时前
国家电网Java面试被问:慢查询的优化方案
java·开发语言·面试
l1t4 小时前
DeepSeek总结的算法 X 与舞蹈链文章
前端·javascript·算法
gihigo19984 小时前
水声信号处理中DEMON谱分析的原理、实现与改进
算法·信号处理
歌_顿4 小时前
微调方法学习总结(万字长文!)
算法
@小码农4 小时前
202512 电子学会 Scratch图形化编程等级考试四级真题(附答案)
java·开发语言·算法
程序猿ZhangSir5 小时前
深入理解 BIO,NIO,AIO 三者的用途和区别?Select,poll,epoll 操作系统函数简介
java·spring·nio
智航GIS5 小时前
6.2 while循环
java·前端·python
2201_757830875 小时前
AOP核心概念
java·前端·数据库
为所欲为、Lynn5 小时前
用FastJson的Filter自动映射枚举
java·spring boot
qq_336313935 小时前
java基础-IO流(转换流)
java·开发语言·python