[63]股票的最大利润
文章目录
题目
假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖 一次 该股票可能获得的利润是多少?
例如一只股票在某些时间节点的价格为[9, 11, 8, 5, 7, 12, 16, 14]。
如果我们能在价格为5的时候买入并在价格为16时卖出,则能收获最大的利润11。
思路
最小时买入,最大值卖出
代码
class Solution {
public:
int maxDiff(vector<int>& nums)
{
if(nums.empty()) return 0;
int res;
for(int i=1,minv=nums[0];i<nums.size();i++)
{
res = max(res,nums[i]-minv); // 更新最大结果
minv = min(minv, nums[i]); // 更新最小值
}
return res;
}
};