121. Best Time to Buy and Sell Stock

https://leetcode.com/problems/best-time-to-buy-and-sell-stock/description/
解法:

class Solution {
    public int maxProfit(int[] prices) {
        if(prices.length < 2){
            return 0;
        }
        int maxprofit = 0;
        int minprice = prices[0];
        int temp;
        for(int ele: prices){
            temp = ele - minprice;
            if(temp > maxprofit){
                maxprofit = temp;
            }
            if(ele < minprice){
                minprice = ele;
            }
        }
        return maxprofit;
    }
}

第一次做覺得理所當(dāng)然的方法第二次居然不敢確定這樣的做法是不是準(zhǔn)確:
有兩點值得指出的是:

  • maxprofit可以將目前最好的結(jié)果保留下來
  • 碰到當(dāng)前price低于minprice的時候敢直接將minprice替換為當(dāng)前price的理由為:
    • 被替換掉的minprice的最優(yōu)解如果存在則已經(jīng)被存儲在maxprofit中
    • 假如最適合被替換的minprice的賣出價在后面且當(dāng)前price低于minprice,則當(dāng)前價格做買入價會有更高的profit
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容