假设你有一个数组,其中第 i 个元素是股票在第 i 天的价格。
你有一次买入和卖出的机会。(只有买入了股票以后才能卖出)。请你设计一个算法来计算可以获得的最大收益。

解题思路:
由于之买卖一次,并且买股票之后才能卖掉股票,所以我们可以得出如下的计算公式:
maxProfit[n] = max{arr[n]-min[n-1], maxProfix[n-1]}
min[n]=min{arr[n], min[n-1]}
其中,maxProfit[n]表示第n天得到的最大值,min[n]表示到第n天为止股票的最底价格

import java.util.*;

public class Solution {
    /**
     * 
     * @param prices int整型一维数组 
     * @return int整型
     */
    public int maxProfit (int[] prices) {
        // write code here
        if (prices.length < 2) return 0;
        int max = 0;
        int min = prices[0];
        for (int i = 1; i < prices.length; i ++) {
            if (prices[i] - min > max) {
                max = prices[i] - min;
            }
            if (prices[i] < min) min = prices[i];
        }
        return max;
    }
}