一、题目
给定一个数组prices,它的第 i 个元素 prices[i]表示一支给定股票第 i 天的价格,只能选择某一天买入这只股票,并且选择未来某一个不同的日子卖出该股票,设计一个算法来计算所能获取的最大利润。返回最大利润,如果不能获取任何利润,返回0。

二、思路
1、遍历数组,记录最小买入价格,每一天都尝试以当前价格卖出,最大利润 = 当前价格 - 历史最低买入价,比较今天卖能赚多少,就能计算出当前的最大利润。
三、代码
java
class Solution {
public int maxProfit(int[] prices) {
int minPrice = Integer.MAX_VALUE,maxProfit = 0,curProfit = 0;
for(int price : prices){
if(minPrice > price){
minPrice = price;
}
curProfit = price - minPrice;
if(maxProfit < curProfit){
maxProfit = curProfit;
}
}
return maxProfit;
}
}