题目描述
假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖 一次 该股票可能获得的利润是多少?
例如一只股票在某些时间节点的价格为 [9,11,8,5,7,12,16,14]。
如果我们能在价格为 5 的时候买入并在价格为 16 时卖出,则能收获最大的利润 11。
双指针
一个记录当前最小值,另一个一直往右记录当前值与当前最小值的差,打擂台更新最大值
class Solution {
public:
int maxDiff(vector<int>& nums) {
if(nums.size()==0) return 0;
int min=nums[0];
int max=0;
for(auto i:nums)
{
if(i<min) min=i;
if(i-min>max) max=i-min;
}
return max;
}
};
//使用两个指针,一个指针记录访问过的最小值(注意这里是访问过的最小值)
//一个指针一直往后走,然后计算他们的差值,保存最大的即可,
京公网安备 11010502036488号