Leetcode121. 買賣股票的最佳時機
給定一個陣列,它的第 i 個元素是一支給定股票第 i 天的價格。
如果你最多隻允許完成一筆交易(即買入和賣出一支股票一次),設計一個演算法來計算你所能獲取的最大利潤。
注意:你不能在買入股票前賣出股票。
示例 1:
輸入: [7,1,5,3,6,4]
輸出: 5
解釋: 在第 2 天(股票價格 = 1)的時候買入,在第 5 天(股票價格 = 6)的時候賣出,最大利潤 = 6-1 = 5 。
注意利潤不能是 7-1 = 6, 因為賣出價格需要大於買入價格;同時,你不能在買入前賣出股票。
思路:
很直觀的看例項1,1該陣列中是最小价格,那麼最大利潤就是1後面中最大的數字減去1.定義兩個變數,第一個是maxprofit(最大利潤),很明顯最大利潤就是價格減去最低價格即maxprofit=max(maxprofit,price-minprice),第二個是最低價格minprice,最低價格就是陣列中的最小元素。minprice=min(minprice,price)。
class Solution {
public:
int maxProfit(vector<int>& prices) {
int minprice = 1e9, maxprofit = 0;//1e9的作用是給變數賦一個初始極大值,原因在於後面的程式碼中需要取此變數和其他變數的最小值。
for(auto price:prices){
maxprofit=max(maxprofit,price-minprice);
minprice=min(minprice,price);
}
return maxprofit;
}
};
相關文章
- 買賣股票的最佳時機 II
- leetcode 121 買賣股票的最佳時機LeetCode
- 122 買賣股票的最佳時機 II
- 121. 買賣股票的最佳時機
- 買賣股票的最佳時機 IV javaJava
- leetcode 123 買賣股票的最佳時機 IIILeetCode
- leetcode 122 買賣股票的最佳時機 IILeetCode
- 122. 買賣股票的最佳時機 II
- 力扣之買賣股票的最佳時機力扣
- 買賣股票的最佳時機系列問題
- 程式碼隨想錄演算法訓練營 | 121.買賣股票的最佳時機,122.買賣股票的最佳時機II,123.買賣股票的最佳時機III演算法
- 121-簡單-買賣股票的最佳時機
- [Leetcode]123.買賣股票的最佳時機3LeetCode
- LeetCode122. 買賣股票的最佳時機 IILeetCode
- 力扣-121. 買賣股票的最佳時機力扣
- LeetCode-122-買賣股票的最佳時機 IILeetCode
- 股票買賣:如何把握股票的最佳買賣點?
- LeetCode-Java:122. 買賣股票的最佳時機ⅡLeetCodeJava
- 力扣之陣列——買賣股票的最佳時機力扣陣列
- 力扣-122. 買賣股票的最佳時機 II力扣
- 陣列筆試題之買賣股票的最佳時機陣列筆試
- 演算法122. 買賣股票的最佳時機 II演算法
- 程式碼隨想錄演算法訓練營第48天 | 188.買賣股票的最佳時機IV 、309.最佳買賣股票時機含冷凍期、 714.買賣股票的最佳時機含手續費演算法
- LeetCode 188 買賣股票的最佳時機IV HERODING的LeetCode之路LeetCode
- 2020-11-19(122. 買賣股票的最佳時機 II)
- 線性dp:LeetCode122.買賣股票的最佳時機llLeetCode
- LeetCode《買賣股票的最佳時機》系列題目,最詳解LeetCode
- leetcode【每日一題】122. 買賣股票的最佳時機 II JavaLeetCode每日一題Java
- 【演算法】【線性表】【陣列】買賣股票的最佳時機演算法陣列
- Day 44 | 714.買賣股票的最佳時機含手續費
- 【演算法】【線性表】【陣列】買賣股票的最佳時機 II演算法陣列
- 買股票的最佳時機(一次買入一次賣出,兩次,多次)
- leetcode 動態規劃 買賣股票的最佳時機含手續費 javaLeetCode動態規劃Java
- 演算法系列-動態規劃(4):買賣股票的最佳時機演算法動態規劃
- [力扣每日一題]714. 買賣股票的最佳時機含手續費力扣每日一題
- Java演算法之動態規劃詳解-買賣股票最佳時機Java演算法動態規劃
- 【leetcode】40-best-time-to-buy-and-sell-stock 力扣 121. 買賣股票的最佳時機LeetCode力扣
- 「leetcode」714. 買賣股票的最佳時機含手續費 超詳細講解LeetCode