国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

【LeetCode】貪心算法--買賣股票的最佳時機 II(122)

xbynet / 510人閱讀

摘要:貪心算法每一步必須滿足一下條件可行的即它必須滿足問題的約束。四題目分析貪心算法,總是做出在當前看來是最好的選擇,不從整體最優上加以考慮,也就是說,只關心當前最優解,按照貪心策略,不關心以后,我們只關心當前利益。

一、寫在前面

為什么要在LeetCode刷題?大家都知道不管是校招還是社招算法題是必考題,而這一部分恰巧是大多數人的短板,所以刷題首先是為了提高自身的編程能力,能夠在算法面試中脫穎而出,拿到滿意的offer。自己是打算考研的,計算機考研數據結構也是必考題,所以刷題的第二個原因就是為了鞏固自己的數據結構知識。

應該如何刷題呢?這兩個月自己是順序刷題的,但是總結的時候發現知識點太零散,前二十題有棧,鏈表,數組等等,自己總結的時候沒有形成一個完整的體系,也沒有清晰的分類,這不是自己想要的,所以自己后期刷題將采用專題的方式,比如數組,鏈表,二叉樹等等。

那么第一個專題就是貪心算法。前20題鏈接【LeetCode】匯總貼(NO.1-20)

自己建了一個LeetCode刷題群,交流自己的刷題心得,現在還沒有到達預定的人數,感興趣的小伙伴可以參加哦,個人微信:wxb950917。

為面試而生,期待你的加入。
二、什么是貪心算法

貪心算法在LeetCode共有41個題目,以中等難度居多。那么什么是貪心算法呢?

貪心算法(又稱貪婪算法)是指,在對問題求解時,總是做出在當前看來是最好的選擇。也就是說,不從整體最優上加以考慮,他所做出的是在某種意義上的局部最優解。

貪心算法每一步必須滿足一下條件:

  1、可行的:即它必須滿足問題的約束。

  2、局部最優:他是當前步驟中所有可行選擇中最佳的局部選擇。

  3、不可取消:即選擇一旦做出,在算法的后面步驟就不可改變了。

學習貪心算法的時候可以結合動態規劃一起來學習,兩者還是很相似的。

三、今日題目

買賣股票的最佳時機 II(122)

給定一個數組,它的第 i 個元素是一支給定股票第 i 天的價格。

設計一個算法來計算你所能獲取的最大利潤。你可以盡可能地完成更多的交易(多次買賣一支股票)。

注意:你不能同時參與多筆交易(你必須在再次購買前出售掉之前的股票)。

示例 1:
輸入: [7,1,5,3,6,4]
輸出: 7
解釋: 在第 2 天(股票價格 = 1)的時候買入,在第 3 天(股票價格 = 5)的時候賣出, 這筆交易所能獲得利潤 = 5-1 = 4 。

 隨后,在第 4 天(股票價格 = 3)的時候買入,在第 5 天(股票價格 = 6)的時候賣出, 這筆交易所能獲得利潤 = 6-3 = 3 。

示例 2:
輸入: [1,2,3,4,5]
輸出: 4
解釋: 在第 1 天(股票價格 = 1)的時候買入,在第 5 天 (股票價格 = 5)的時候賣出, 這筆交易所能獲得利潤 = 5-1 = 4 。

 注意你不能在第 1 天和第 2 天接連購買股票,之后再將它們賣出。
 因為這樣屬于同時參與了多筆交易,你必須在再次購買前出售掉之前的股票。

示例 3:
輸入: [7,6,4,3,1]
輸出: 0
解釋: 在這種情況下, 沒有交易完成, 所以最大利潤為 0。

四、題目分析

貪心算法,總是做出在當前看來是最好的選擇,不從整體最優上加以考慮,也就是說,只關心當前最優解,按照貪心策略,不關心以后,我們只關心當前利益。第0天買入,花費prices[0],第一天賣出,得到prices[1],那么我們的收獲就是profit = prices[1] - prices[0],那么有兩種情況

(1)當profit > 0 時,趕緊買入賣出,能賺一筆是一筆。

(2)當profit <= 0 時,再買入賣出的話,那就是傻了,虧錢。

以此方式類推下去,即得最大利潤。

五、代碼實現

class Solution:

def maxProfit(self, prices):
    """
    :type prices: List[int]
    :rtype: int
    """
    profit = 0
    temp=0
    for i in range(1,len(prices)):
        temp=prices[i] - prices[i-1]
        if temp>0:
            profit+=temp
    return profit

【推薦閱讀】

【Python爬蟲】初識爬蟲(1)

用Python來一場人工造雪

機器學習實戰--住房月租金預測(1)

Python之禪

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/45039.html

相關文章

  • 大廠算法面試之leetcode精講3.動態規劃

    摘要:動態規劃問題一定會具備最優子結構,才能通過子問題的最值得到原問題的最值。另外,雖然動態規劃的核心思想就是窮舉求最值,但是問題可以千變萬化,窮舉所有可行解其實并不是一件容易的事,只有列出正確的狀態轉移方程才能正確地窮舉。 大廠算法面試之leetcode精講3.動態規劃視頻教程(高效學習):點擊學習目錄:1.開篇介...

    番茄西紅柿 評論0 收藏2637
  • 【刷算法LeetCode.150-買賣股票最佳時機 II

    摘要:題目描述給定一個數組,它的第個元素是一支給定股票第天的價格。設計一個算法來計算你所能獲取的最大利潤。你可以盡可能地完成更多的交易多次買賣一支股票。隨后,在第天股票價格的時候買入,在第天股票價格的時候賣出這筆交易所能獲得利潤。 題目描述 給定一個數組,它的第 i 個元素是一支給定股票第 i 天的價格。 設計一個算法來計算你所能獲取的最大利潤。你可以盡可能地完成更多的交易(多次買賣一支股票...

    Vultr 評論0 收藏0
  • LeetCode 攻略 - 2019 年 7 月上半月匯總(55 題攻略)

    摘要:微信公眾號記錄截圖記錄截圖目前關于這塊算法與數據結構的安排前。已攻略返回目錄目前已攻略篇文章。會根據題解以及留言內容,進行補充,并添加上提供題解的小伙伴的昵稱和地址。本許可協議授權之外的使用權限可以從處獲得。 Create by jsliang on 2019-07-15 11:54:45 Recently revised in 2019-07-15 15:25:25 一 目錄 不...

    warmcheng 評論0 收藏0
  • LeetCode 攻略 - 2019 年 7 月下半月匯總(100 題攻略)

    摘要:月下半旬攻略道題,目前已攻略題。目前簡單難度攻略已經到題,所以后面會調整自己,在刷算法與數據結構的同時,攻略中等難度的題目。 Create by jsliang on 2019-07-30 16:15:37 Recently revised in 2019-07-30 17:04:20 7 月下半旬攻略 45 道題,目前已攻略 100 題。 一 目錄 不折騰的前端,和咸魚有什么區別...

    tain335 評論0 收藏0
  • TypeScript實現數組相關簡單算法

    摘要:本文只是簡單理解算法,并不會深入的討論。大部分來自數組部分。如果數組中每個元素都不相同,則返回。示例輸入輸出加給定一個由整數組成的非空數組所表示的非負整數,在該數的基礎上加一。盡量減少操作次數。 算法(algorithm),在數學(算學)和計算機科學之中,為任何良定義的具體計算步驟的一個序列,常用于計算、數據處理和自動推理。精確而言,算法是一個表示為有限長列表的有效方法。算法應包含清晰...

    cloud 評論0 收藏0

發表評論

0條評論

xbynet

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<