参考Hot100-121
题目:
题解:
1.
2.
package com.shuzu;
/**
* 121.买卖股票的最佳时机https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock/
* 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。
*
* 如果你最多只允许完成一笔交易(即买入和卖出一支股票一次),设计一个算法来计算你所能获取的最大利润。
*
* 注意:你不能在买入股票前卖出股票。
*/
public class No121 {
//1.暴力求解
/**
* 我们需要找出给定数组中两个数字之间的最大差值(即,最大利润)。此外,第二个数字(卖出价格)必须大于第一个数字(买入价格)。
*
* 形式上,对于每组 i 和 j(其中 j > i)我们需要找出 max(prices[j] - prices[i])。
*/
public int maxProfit1(int prices[]) {
int maxprofit = 0;
for (int i = 0; i < prices.length - 1; i++) {
for (int j = i + 1; j < prices.length; j++) {
int profit = prices[j] - prices[i];
if (profit > maxprofit) {
maxprofit = profit;
}
}
}
return maxprofit;
}
//2.一次遍历--动态规划
/**
* 在题目中,我们只要用一个变量记录一个历史最低价格 minprice,我们就可以假设自己的股票是在那天买的。
* 那么我们在第 i 天卖出股票能得到的利润就是 prices[i] - minprice。
*/
public int maxProfit2(int prices[]) {
int minprice = Integer.MAX_VALUE;
int maxprofit = 0;
for (int i = 0; i < prices.length; i++) {
if (prices[i] < minprice) {
minprice = prices[i];
} else if (prices[i] - minprice > maxprofit) {
maxprofit = prices[i] - minprice;
}
}
return maxprofit;
}
}
补充知识:
参考Java int的最大值