欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python貪心算法Greedy Algorithm解決案例小結

 更新時間:2023年06月16日 15:18:40   作者:ShowMeCoding  
這篇文章主要為大家介紹了Python貪心算法Greedy Algorithm解決案例小結,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

貪心算法

在每一次做決策時,保證當下的決策是最優(yōu)的,從而使得最后的結果是最優(yōu)的。

分發(fā)餅干

455. 分發(fā)餅干

假設你是一位很棒的家長,想要給你的孩子們一些小餅干。但是,每個孩子最多只能給一塊餅干。

對每個孩子 i,都有一個胃口值 g[i],這是能讓孩子們滿足胃口的餅干的最小尺寸;并且每塊餅干 j,都有一個尺寸 s[j] 。如果 s[j] >= g[i],我們可以將這個餅干 j 分配給孩子 i ,這個孩子會得到滿足。你的目標是盡可能滿足越多數量的孩子,并輸出這個最大數值。

# 最好的選擇是不要浪費餅干
class Solution:
    def findContentChildren(self, g: List[int], s: List[int]) -> int:
        # 先對胃口值和餅干尺寸排序
        g.sort()
        s.sort()
        g_l = len(g)
        g_index = 0
        s_l = len(s)
        s_index = 0
        # 計數
        count = 0
        # 終止條件:孩子數 和 餅干數是否在條件內
        while g_index < g_l and s_index < s_l:
            # 胃口小于餅干
            if g[g_index] <= s[s_index]:
                # 餅干被消耗
                count += 1
                g_index += 1
                s_index += 1
            # 胃口大于餅干
            else:
                # 尋求更多的餅干滿足胃口
                s_index += 1
        return count

無重疊區(qū)間

435. 無重疊區(qū)間

給定一個區(qū)間的集合 intervals ,其中 intervals[i] = [starti, endi] 。返回 需要移除區(qū)間的最小數量,使剩余區(qū)間互不重疊 。

輸入: intervals = [[1,2],[2,3],[3,4],[1,3]]
輸出: 1

解釋: 移除 [1,3] 后,剩下的區(qū)間沒有重疊。

class Solution:
    def eraseOverlapIntervals(self, intervals: List[List[int]]) -> int:
        # 判斷是否為空
        if not intervals:
            return 0
        # 對end值進行升序排序
        intervals.sort(key = lambda x: x[1])
        # 維護一個最小值
        end_pos = intervals[0][1]
        # 只有單個區(qū)間時無重疊?。。∫虼硕x為1
        count = 1
        # 終止條件
        for i in range(1, len(intervals)):
            # 判斷是否連續(xù)
            if end_pos <= intervals[i][0]:
                count += 1
                end_pos = intervals[i][1]
        return len(intervals) - count

二維數組排序的方法:intervals.sort(key = lambda x: x[1])
思路轉換:求最小移除數組,意味著求最大連續(xù)數組

檸檬水找零

860. 檸檬水找零

輸入:bills = [5,5,5,10,20]
輸出:true

解釋:

前 3 位顧客那里,我們按順序收取 3 張 5 美元的鈔票。

第 4 位顧客那里,我們收取一張 10 美元的鈔票,并返還 5 美元。

第 5 位顧客那里,我們找還一張 10 美元的鈔票和一張 5 美元的鈔票。

由于所有客戶都得到了正確的找零,所以我們輸出 true。

class Solution:
    def lemonadeChange(self, bills: List[int]) -> bool:
        five, ten, twenty = 0, 0, 0
        for bill in bills:
            if bill == 5:
                five += 1
            if bill == 10:
                # 是否可以找回
                if five <= 0:
                    return False
                # 收下 10 元
                ten += 1
                # 找回 5 元
                five -= 1
            if bill == 20:
                # 是否可以找回一張5元和一張10元
                if five > 0 and ten > 0:
                    five -= 1
                    ten -= 1
                    twenty += 1
                # 是否可以找回三張 5 元
                elif five >= 3:
                    five -= 3
                    twenty += 1
                else:
                    return False
        return True

以上就是Python貪心算法Greedy Algorithm解決案例小結的詳細內容,更多關于Python貪心算法的資料請關注腳本之家其它相關文章!

相關文章

  • Python?Streamlit制作交互式可視化網頁應用實例

    Python?Streamlit制作交互式可視化網頁應用實例

    這篇文章主要為大家介紹了Python?Streamlit制作交互式可視化網頁應用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • python中ImageTk.PhotoImage()不顯示圖片卻不報錯問題解決

    python中ImageTk.PhotoImage()不顯示圖片卻不報錯問題解決

    這篇文章主要給大家介紹了關于在python中ImageTk.PhotoImage()不顯示圖片卻不報錯問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-12-12
  • python 寫入csv亂碼問題解決方法

    python 寫入csv亂碼問題解決方法

    這篇文章主要介紹了python 寫入csv亂碼問題解決方法的相關資料,需要的朋友可以參考下
    2016-10-10
  • python 基于wx實現音樂播放

    python 基于wx實現音樂播放

    這篇文章主要介紹了python 基于wx實現音樂播放的示例代碼,幫助大家更好的理解和學習python,感興趣的朋友可以了解下
    2020-11-11
  • python矩陣列的實現示例

    python矩陣列的實現示例

    在Python和NumPy庫的幫助下,矩陣列可以很容易地進行各種操作,本文主要介紹了python矩陣列的實現示例,具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • tensorflow 加載部分變量的實例講解

    tensorflow 加載部分變量的實例講解

    今天小編就為大家分享一篇tensorflow 加載部分變量的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • python機器學習使數據更鮮活的可視化工具Pandas_Alive

    python機器學習使數據更鮮活的可視化工具Pandas_Alive

    今天我分享大家一款非常棒的動畫可視化工具:Pandas_Alive,它以?matplotlib?繪圖為后端,不僅可以創(chuàng)建出令人驚嘆的動畫可視化,而且使用方法非常簡單。本文詳情如下
    2021-11-11
  • Python基礎學習之深淺拷貝問題及遞歸函數練習

    Python基礎學習之深淺拷貝問題及遞歸函數練習

    在實際工作中,經常涉及到數據的傳遞。這篇文章主要為大家介紹了Python的一些基礎學習:深拷貝與淺拷貝問題、遞歸函數的練習,需要的朋友可以參考一下
    2021-12-12
  • YOLOv5車牌識別實戰(zhàn)教程(八)Web應用與API開發(fā)

    YOLOv5車牌識別實戰(zhàn)教程(八)Web應用與API開發(fā)

    這篇文章主要介紹了YOLOv5車牌識別實戰(zhàn)教程(八)Web應用與API開發(fā),在這個教程中,我們將一步步教你如何使用YOLOv5進行車牌識別,幫助你快速掌握YOLOv5車牌識別技能,需要的朋友可以參考下
    2023-04-04
  • python 讀寫文件包含多種編碼格式的解決方式

    python 讀寫文件包含多種編碼格式的解決方式

    今天小編就為大家分享一篇python 讀寫文件包含多種編碼格式的解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12

最新評論