国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】

這篇具有很好參考價(jià)值的文章主要介紹了【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】

?? 算法題 ??

?? 算法刷題專欄 | 面試必備算法 | 面試高頻算法 ??
?? 越難的東西,越要努力堅(jiān)持,因?yàn)樗哂泻芨叩膬r(jià)值,算法就是這樣?
?? 作者簡(jiǎn)介:碩風(fēng)和煒,CSDN-Java領(lǐng)域新星創(chuàng)作者??,保研|國(guó)家獎(jiǎng)學(xué)金|高中學(xué)習(xí)JAVA|大學(xué)完善JAVA開發(fā)技術(shù)棧|面試刷題|面經(jīng)八股文|經(jīng)驗(yàn)分享|好用的網(wǎng)站工具分享??????
?? 恭喜你發(fā)現(xiàn)一枚寶藏博主,趕快收入囊中吧??
?? 人生如棋,我愿為卒,行動(dòng)雖慢,可誰(shuí)曾見(jiàn)我后退一步?????

?? 算法題 ??

【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】

?? 知識(shí)回顧

大家在學(xué)習(xí)這道題目之前,可以先去看一下買賣股票最佳時(shí)機(jī)1,再看這個(gè)題目就更容易理解了。
博客的地址放到這里了,可以先去學(xué)習(xí)一下這到題目。

  • 【LeetCode股票買賣系列:121. 買賣股票的最佳時(shí)機(jī) | 一次遍歷 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】
  • 【LeetCode股票買賣系列:122. 買賣股票的最佳時(shí)機(jī) II | 貪心 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】
  • 【LeetCode股票買賣系列:123. 買賣股票的最佳時(shí)機(jī) III 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】
  • 【LeetCode股票買賣系列:188. 買賣股票的最佳時(shí)機(jī) IV | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】

?? 題目鏈接

  • 309. 最佳買賣股票時(shí)機(jī)含冷凍期

? 題目描述

給定一個(gè)整數(shù)數(shù)組prices,其中第 prices[i] 表示第 i 天的股票價(jià)格 。?

設(shè)計(jì)一個(gè)算法計(jì)算出最大利潤(rùn)。在滿足以下約束條件下,你可以盡可能地完成更多的交易(多次買賣一支股票):

賣出股票后,你無(wú)法在第二天買入股票 (即冷凍期為 1 天)。
注意:你不能同時(shí)參與多筆交易(你必須在再次購(gòu)買前出售掉之前的股票)。

示例 1:

輸入: prices = [1,2,3,0,2]
輸出: 3
解釋: 對(duì)應(yīng)的交易狀態(tài)為: [買入, 賣出, 冷凍期, 買入, 賣出]
示例 2:

輸入: prices = [1]
輸出: 0

提示:

1 <= prices.length <= 5000
0 <= prices[i] <= 1000

?? 求解思路&實(shí)現(xiàn)代碼&運(yùn)行結(jié)果


? 暴力法

?? 求解思路
  1. 首先該題目核心求解思路我們之前也已經(jīng)講過(guò)了,不會(huì)的同學(xué)可以看一下之前的文章內(nèi)容;
  2. 我們將這道題目區(qū)別于其它股票題目不同的內(nèi)容標(biāo)記出來(lái),可以多次買賣 && 賣出股票后,你無(wú)法在第二天買入股票 (即冷凍期為 1 天);
  3. 第一個(gè)限制條件我們?cè)趺慈プ?,前面都已?jīng)講過(guò)了,我們著重看一下第二個(gè)限制條件,第二個(gè)條件其實(shí)也比較簡(jiǎn)單,主要就是如果當(dāng)前我們持有股票,并且答案是來(lái)自此時(shí)我們需要買入的時(shí)候,那么此時(shí)答案必須來(lái)自前倆天不持有股票的狀態(tài)。
  4. 接下來(lái)我們就來(lái)實(shí)現(xiàn)一下具體的代碼。
?? 實(shí)現(xiàn)代碼
class Solution {

    int[] prices;

    public int maxProfit(int[] prices) {
        this.prices=prices;
        int n=prices.length;
        return process(n-1,0);
    }

    public int process(int i,int flag){
        if(i<0) return flag==1?Integer.MIN_VALUE:0;
        if(flag==1) return Math.max(process(i-1,1),process(i-2,0)-prices[i]);
        return Math.max(process(i-1,0),process(i-1,1)+prices[i]);
    }
}
?? 運(yùn)行結(jié)果

果然不出我們所料,時(shí)間超限了,不要緊張,我們來(lái)繼續(xù)優(yōu)化它!

【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】


? 記憶化搜索

?? 求解思路
  1. 因?yàn)樵谶f歸的過(guò)程中,會(huì)重復(fù)的出現(xiàn)一些多次計(jì)算的結(jié)果,我們通過(guò)開辟一個(gè)數(shù)組,將結(jié)果提前緩存下來(lái),算過(guò)的直接返回,避免重復(fù)計(jì)算,通過(guò)空間來(lái)去換我們的時(shí)間。
?? 實(shí)現(xiàn)代碼
class Solution {
    int[] prices;
    int[][] dp;
    public int maxProfit(int[] prices) {
        this.prices=prices;
        int n=prices.length;
        dp=new int[n][2];
        for(int i=0;i<n;i++) Arrays.fill(dp[i],-1);
        return process(n-1,0);
    }

    public int process(int i,int flag){
        if(i<0) return flag==1?Integer.MIN_VALUE:0;
        if(dp[i][flag]!=-1) return dp[i][flag];
        if(flag==1) return dp[i][flag]=Math.max(process(i-1,1),process(i-2,0)-prices[i]);
        return dp[i][flag]=Math.max(process(i-1,0),process(i-1,1)+prices[i]);
    }
}
?? 運(yùn)行結(jié)果

加一個(gè)緩存表,通過(guò)?。。?br>【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】


? 動(dòng)態(tài)規(guī)劃

?? 求解思路
  1. 有了遞歸,有了記憶化搜索,接下來(lái)就是動(dòng)態(tài)規(guī)劃了,直接上手。
?? 實(shí)現(xiàn)代碼
class Solution {
    int[] prices;
    int[][] dp;
    public int maxProfit(int[] prices) {
        this.prices=prices;
        int n=prices.length;
        dp=new int[n][2];
        dp[0][1]=-prices[0];
        dp[0][0]=0;
        if(n>1){
            dp[1][1]=Math.max(dp[0][1],-prices[1]);
            dp[1][0]=Math.max(dp[0][0],dp[0][1]+prices[1]);
        }
        for(int i=2;i<n;i++){
            dp[i][1]=Math.max(dp[i-1][1],dp[i-2][0]-prices[i]);
            dp[i][0]=Math.max(dp[i-1][0],dp[i-1][1]+prices[i]);
        }
        return dp[n-1][0];
    }
}
?? 運(yùn)行結(jié)果

搞定,簡(jiǎn)直不要太爽!
【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】


?? 共勉

最后,我想和大家分享一句一直激勵(lì)我的座右銘,希望可以與大家共勉!

【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】

【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-432483.html

到了這里,關(guān)于【LeetCode股票買賣系列:309. 最佳買賣股票時(shí)機(jī)含冷凍期 | 暴力遞歸=>記憶化搜索=>動(dòng)態(tài)規(guī)劃】的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 力扣 309. 買賣股票的最佳時(shí)機(jī)含冷凍期

    力扣 309. 買賣股票的最佳時(shí)機(jī)含冷凍期

    題目來(lái)源:https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-with-cooldown/description/ C++題解:動(dòng)態(tài)規(guī)劃 狀態(tài)1:表示持有股票。更新為之前持有股票(dp[i-1][0])或者不持有股票且不處于冷凍期后買入(dp[i-1][2]-prices[i])。 狀態(tài)2:表示不持有股票且處于冷凍期,即賣出。更新為持有

    2024年02月22日
    瀏覽(26)
  • 【第51天| 309.最佳買賣股票時(shí)機(jī)含冷凍期 ● 714.買賣股票的最佳時(shí)機(jī)含手續(xù)費(fèi) 】

    三個(gè)狀態(tài): 1. 當(dāng)前持有股票 狀態(tài)1 2. 當(dāng)前不持有股票,且不是今天賣出的股票 狀態(tài)2 3. 當(dāng)前不持有股票, 且股票是今天賣出的 狀態(tài)3 題目要求前一天賣出了股票今天就不能買。所以今天持有股票 狀態(tài)1 一定是昨天的 狀態(tài)2 在今天買了股票,或者就是保持了昨天的 狀態(tài)1 。 狀

    2024年02月08日
    瀏覽(22)
  • dp算法 力扣309最佳買賣股票時(shí)機(jī)含冷凍期

    dp算法 力扣309最佳買賣股票時(shí)機(jī)含冷凍期

    給定一個(gè)整數(shù)數(shù)組prices,其中第??prices[i]?表示第?i?天的股票價(jià)格 。? 設(shè)計(jì)一個(gè)算法計(jì)算出最大利潤(rùn)。在滿足以下約束條件下,你可以盡可能地完成更多的交易(多次買賣一支股票): 賣出股票后,你無(wú)法在第二天買入股票 (即冷凍期為 1 天)。 注意:你不能同時(shí)參與多筆交

    2024年02月14日
    瀏覽(20)
  • 【算法】力扣【動(dòng)態(tài)規(guī)劃、狀態(tài)機(jī)】309. 買賣股票的最佳時(shí)機(jī)含冷凍期

    309. 買賣股票的最佳時(shí)機(jī)含冷凍期 本文介紹解決力扣平臺(tái)上第309號(hào)問(wèn)題——“買賣股票的最佳時(shí)機(jī)含冷凍期”的算法。這是一個(gè)中等難度的問(wèn)題,其核心是通過(guò)設(shè)計(jì)一個(gè)算法來(lái)計(jì)算在給定的股票價(jià)格數(shù)組 prices 下,能夠獲取的最大利潤(rùn)。股票價(jià)格數(shù)組 prices 中的每個(gè)元素 pric

    2024年01月18日
    瀏覽(26)
  • 【LeetCode】買賣股票的最佳時(shí)機(jī)含冷凍期

    【LeetCode】買賣股票的最佳時(shí)機(jī)含冷凍期

    鏈接: 買賣股票的最佳時(shí)機(jī)含冷凍期 題目描述 算法分析 程序設(shè)計(jì)

    2024年02月13日
    瀏覽(17)
  • 【學(xué)會(huì)動(dòng)態(tài)規(guī)劃】最佳買賣股票時(shí)機(jī)含冷凍期(15)

    【學(xué)會(huì)動(dòng)態(tài)規(guī)劃】最佳買賣股票時(shí)機(jī)含冷凍期(15)

    目錄 動(dòng)態(tài)規(guī)劃怎么學(xué)? 1. 題目解析 2. 算法原理 1. 狀態(tài)表示 2. 狀態(tài)轉(zhuǎn)移方程 3. 初始化 4. 填表順序 5. 返回值 3. 代碼編寫 寫在最后: 學(xué)習(xí)一個(gè)算法沒(méi)有捷徑,更何況是學(xué)習(xí)動(dòng)態(tài)規(guī)劃, 跟我一起刷動(dòng)態(tài)規(guī)劃算法題,一起學(xué)會(huì)動(dòng)態(tài)規(guī)劃! 題目鏈接:309. 最佳買賣股票時(shí)機(jī)含冷凍

    2024年02月14日
    瀏覽(39)
  • 算法刷題Day 51 最佳買賣股票時(shí)機(jī)含冷凍期+買賣股票的最佳時(shí)期含手續(xù)費(fèi)

    關(guān)鍵是要畫出狀態(tài)轉(zhuǎn)移圖 然后根據(jù)狀態(tài)轉(zhuǎn)移圖來(lái)寫狀態(tài)轉(zhuǎn)移方程 這道題其實(shí)就是在買賣股票II的基礎(chǔ)上加入一點(diǎn)變化而已,代碼框架還是那個(gè)框架。

    2024年02月15日
    瀏覽(30)
  • 動(dòng)態(tài)規(guī)劃--買賣股票含冷凍期309

    動(dòng)態(tài)規(guī)劃--買賣股票含冷凍期309

    ? ? ? ? 這道題很明顯下一天的利潤(rùn)需要由上一天的狀態(tài)推導(dǎo)出來(lái),所以這是很明顯的動(dòng)態(tài)規(guī)劃問(wèn)題 ????????普通的股票問(wèn)題有兩種狀態(tài):持有股票的利潤(rùn),不持有股票的利潤(rùn),但這道題有一個(gè)冷凍期,使得這道題有4種狀態(tài): ? ? ? ? 1、 持有股票的利潤(rùn) ;? ? ? ? ?

    2024年04月28日
    瀏覽(24)
  • 《LeetCode》—— 買賣股票的最佳時(shí)機(jī)

    《LeetCode》—— 買賣股票的最佳時(shí)機(jī)

    本期,我將給大家講解的是有關(guān)動(dòng)態(tài)規(guī)劃類的題—— 買賣股票的最佳時(shí)機(jī) 。這個(gè)系列總共有四道題。接下來(lái),讓我們一起去看看!??! 目錄 (一)買賣股票的最佳時(shí)機(jī) (二)買賣股票的最佳時(shí)機(jī) II (三)買賣股票的最佳時(shí)機(jī) III (四)買賣股票的最佳時(shí)機(jī) IV LeetCode題目鏈

    2024年02月05日
    瀏覽(23)
  • leetcode 121. 買賣股票的最佳時(shí)機(jī)

    leetcode 121. 買賣股票的最佳時(shí)機(jī)

    ? ? ? ? ?本題用dp算法做, dp[i]的含義:前 i+1天能獲得的最大利潤(rùn) 。 然后每次循環(huán)時(shí)需要維護(hù)一個(gè)最小值 min_num?:即 i+1天中股票的最低價(jià) 。剩下的步驟都很常規(guī),代碼如下: ? ? ? ? dp[i][0]:第i天持有股票所擁有的最多現(xiàn)金。? ? ? ? ? dp[i][1]:第i天不持有股票所擁有的最

    2024年02月12日
    瀏覽(20)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包