题解 | 买卖股票的最好时机(一)

买卖股票的最好时机(一)

https://www.nowcoder.com/practice/351b87e53d0d44928f4de9b6217d36bb

//  #牛客春招刷题训练营# https://www.nowcoder.com/discuss/726480854079250432
//  动态规划, 当天买入股票的最大收益 = 当天及之后的股票的最高价(后缀最大值) - 当天的股票价, 通过遍历去最大值即可,时间复杂度是O(3n)=O(n)
#include<iostream>
#include<vector>
#include<algorithm>
#define pre(i,j,k) for (int i = j; i < k; i++)
using namespace std;
int main(){
  ios_base::sync_with_stdio(false),cin.tie(0),cout.tie(0);
  int n;
  cin >> n;
  vector<int> sufmax(n + 1), a(n);
  pre(i, 0, n) cin >> a[i];
  for (int i = n - 1; i >= 0; i--) sufmax[i] = max(sufmax[i + 1], a[i]);
  int ans = 0;
  pre(i, 0, n) ans = max(ans, sufmax[i] - a[i]);
  cout << ans;
  return 0;
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-23 14:13
这是聊岔撇了吗,相同的话问了两遍
吴offer选手:上下文切换这一块
点赞 评论 收藏
分享
06-07 00:00
已编辑
腾讯_后端开发
点赞 评论 收藏
分享
07-11 22:27
中南大学 Java
程序员牛肉:学历的话没问题。但是没问题的也就只有学历了。 其实你的整体架构是正确的,博客接着干。但是项目有点过于简单了。从后端的角度上讲,你这也就是刚入门的水平,所以肯定约面试够呛。 如果你要应聘后端岗位,那你第一个项目竟然是仿写操作系统。这个你要面试官咋问你。你一定要记住一点,你简历上写的所有的东西,都是为了证明你有能力胜任当前的岗位,而不是为了证明你自己会什么。 如果你只是浅浅的做几个项目,描述也都是烂大街。技术点也都是各种混水类的配置类需求,那你就不要幻想自己能走多远。一定要保持思考,保持学习。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务