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

题目:

暴力双循环会时间超限

一次循环,不断更新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;
    }
相关推荐
java修仙传3 分钟前
力扣hot100:寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
ArabySide5 分钟前
【Java】重构之善用多态解耦,记录一次模板方法实践
java·重构·模板方法模式
胖咕噜的稞达鸭7 分钟前
算法日记专题:位运算II( 只出现一次的数字I II III 面试题:消失的两个数字 比特位计数)
c++·算法·动态规划
wanghowie11 分钟前
01.03 Java基础篇|面向对象核心与设计实践
java·开发语言
txzrxz16 分钟前
图的存储
算法·深度优先·图论
vortex517 分钟前
ORM是什么?如何理解ORM?ORM的优缺点?
java·数据库·sql·mysql·oracle·orm
Algebraaaaa19 分钟前
为什么线程阻塞要用.join而不是.wait
java·c++·python
Knight_AL21 分钟前
深入解析 JVM 垃圾回收算法:经典 vs 新型 GC 算法
jvm·算法
是苏浙22 分钟前
零基础入门Java之设计图书管理系统
java·开发语言
墨雪不会编程29 分钟前
C++内存管理深度剖析
java·开发语言·c++