买卖股票最大收益
买卖股票的最佳时机
http://www.nowcoder.com/questionTerminal/64b4262d4e6d4f6181cd45446a5821ec
假设你有一个数组,其中第 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;
}
}
查看11道真题和解析