当前位置:网站首页>【 LeetCode 】 121. The best time to buy stocks
【 LeetCode 】 121. The best time to buy stocks
2022-07-29 15:02:00 【Crispy~】
题目
给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格.你只能选择 Buy this stock one day,并选择在 Sell the stock on a different day in the future.设计一个算法来计算你所能获取的最大利润.返回你可以从这笔交易中获取的最大利润.如果你不能获取任何利润,返回 0 .
示例 1:
输入:[7,1,5,3,6,4]
输出:5
解释:在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 .
注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票.
示例 2:
输入:prices = [7,6,4,3,1]
输出:0
解释:在这种情况下, 没有交易完成, 所以最大利润为 0.
提示:
1 <= prices.length <= 105
0 <= prices[i] <= 104
题解
暴力遍历,Apparently time out
class Solution {
public:
int maxProfit(vector<int>& prices) {
int result=0;
int len=prices.size();
for(int i=0;i<len-1;i++)
{
for(int j=i+1;j<len;j++)
{
result = max(result,prices[j]-prices[i]);
}
}
return result;
}
};
低买高抛,So you can use a variable before loggingithe lowest value of the day,then get theiday's earnings to compare
class Solution {
public:
int maxProfit(vector<int>& prices) {
int min_price=prices[0];//记录前i天的最低价
int result=0;//存储结果
for(int k:prices)
{
result = max(result,k-min_price);//Update top yield
min_price = min(min_price,k);//更新最低价
}
return result;
}
};
边栏推荐
猜你喜欢
随机推荐
基于变胞机构的移动机器人构型设计研究综述
极市直播丨严彬-Unicorn:走向目标跟踪的大一统(ECCV2022 Oral)
【IIC通信】Chap.2 (I2C)IIC协议的特点;为什么IIC需要开漏输出、上拉电阻?
建议尽快优化搜索体验
打卡广汽本田喜悦安全驾驶中心,体验最刁钻的场地训练
如何返回一个数字的所有质因数?
【LeetCode】350. 两个数组的交集 II
正斜杠 “/” 与反斜杠 “\”辨析
Pinia状态持久化
中国互联网科技企业群狼围攻,谷歌终于遭受重挫导致利润大跌,它为推动鸿蒙的发展而后悔...
dedecms编辑器支持pdf导入
基于JSP&Servlet实现的众筹平台系统
MySQL索引常见面试题(2022版)
升级openssl1.1.1(mix2s哪个版本不断流)
ArcGIS Pro与ArcGis区别
三 RedisTemplate 序列化机制配置实战
兆骑科创赛事活动承办,项目路演,人才引进平台
字典树笔记(自用)
kubernetes中正strace etcd
WOLFLAB一方老师为什么要写网络虚拟化《VMware NSX-T卷2》路由架构-2









