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

python 貪心算法的實(shí)現(xiàn)

 更新時(shí)間:2020年09月18日 17:17:38   作者:Achilles_Heel  
這篇文章主要介紹了python 貪心算法的實(shí)現(xiàn),幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下

貪心算法

貪心算法(又稱(chēng)貪婪算法)是指,在對(duì)問(wèn)題求解時(shí),總是做出在當(dāng)前看來(lái)是最好的選擇。也就是說(shuō),不從整體最優(yōu)上加以考慮,他所做出的是在某種意義上的局部最優(yōu)解。

貪心算法不是對(duì)所有問(wèn)題都能得到整體最優(yōu)解,關(guān)鍵是貪心策略的選擇,選擇的貪心策略必須具備無(wú)后效性,即某個(gè)狀態(tài)以前的過(guò)程不會(huì)影響以后的狀態(tài),只與當(dāng)前狀態(tài)有關(guān)。

基本思路

思想

貪心算法的基本思路是從問(wèn)題的某一個(gè)初始解出發(fā)一步一步地進(jìn)行,根據(jù)某個(gè)優(yōu)化測(cè)度,每一步都要確保能獲得局部最優(yōu)解。每一步只考慮一個(gè)數(shù)據(jù),他的選取應(yīng)該滿(mǎn)足局部?jī)?yōu)化的條件。若下一個(gè)數(shù)據(jù)和部分最優(yōu)解連在一起不再是可行解時(shí),就不把該數(shù)據(jù)添加到部分解中,直到把所有數(shù)據(jù)枚舉完,或者不能再添加算法停止 。

步驟

  1. 遍歷初始集合X中的備選元素
  2. 利用貪心策略在X中確定一個(gè)元素,并將其加入到可行解S中
  3. 得到可行解S

P即為貪心策略,用來(lái)選擇符合條件的元素。

例子——硬幣找零

假設(shè)某國(guó)硬幣面值有1,5,10,25,100元五種面額,若店員為顧客找零時(shí),需要給顧客找零a=36元,求硬幣數(shù)最少的情況。

這里我們的貪心策略為:

先找到最接近a的值,然后對(duì)a進(jìn)行更新,然后進(jìn)行循環(huán)。

代碼實(shí)現(xiàn)

def shortNum(a):
  coins = [1,5,10,25,100]
  out = []
  coins = coins[::-1]

  for i in coins:
    num = a//i
    out=out+[i,]*num
    a = a-num*i
    if a<=0:
      break
  return out
a = 36
print(shortNum(a))

例子——任務(wù)規(guī)劃

問(wèn)題描述:

輸入為任務(wù)集合X= [r1,r2,r3,...,rn],每個(gè)任務(wù)ri,都對(duì)應(yīng)著一個(gè)起始時(shí)間ai與結(jié)束時(shí)間bi

要求輸出為最多的相容的任務(wù)集。

 如上圖,r1與r2相容,r3與r1和r2都不相容。

那么這里的貪心策略我們可以設(shè)為:

  1. 先將結(jié)束時(shí)間最短的任務(wù)加入到S中,
  2. 再?gòu)氖O碌娜蝿?wù)的任務(wù)中選擇結(jié)束時(shí)間最短的,且判斷與S集合中的任務(wù)是否相容
  3. 若不相容,則換下一個(gè)時(shí)間最短的任務(wù),并進(jìn)行比較
  4. 循環(huán),直至X為空。

代碼實(shí)現(xiàn)

# 任務(wù)規(guī)劃
from collections import OrderedDict
task = OrderedDict()
task['r1'] = [0,4]
task['r2'] = [5,8]
task['r3'] = [10,13]
task['r4'] = [15,18]
task['r5'] = [7,11]
task['r6'] = [2,6]
task['r7'] = [2,6]
task['r8'] = [2,6]
task['r9'] = [12,16]
task['r10'] = [12,16]
task['r11'] = [12,16]
task['r12'] = [0,3]


listTask = list(task.items())
# 根據(jù)bi進(jìn)行排序,結(jié)束時(shí)間早的在前面(冒泡排序)
for i in range(len(listTask)-1):
  for j in range(len(listTask)-i-1):
    if listTask[j][1][1] > listTask[j+1][1][1]:
      listTask[j],listTask[j+1]=listTask[j+1],listTask[j]
print(listTask)
out = []
out.append(listTask.pop(0))
def isValid(temp,out):
  for k in range(len(out)):
    if temp[1][0]<out[k][1][1]:
      # 相交
      return False
  return True

for j in range(len(listTask)):
  temp = listTask.pop(0)
  # 判斷是否相交
  #   相交則continue
  #   不相交則out.append(temp)
  for k in range(len(out)):
    if isValid(temp,out):
      out.append(temp)
    # else:continue 語(yǔ)句可以不寫(xiě)
    else:
      continue
print(out)

以上就是python 貪心算法的實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于python 貪心算法的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Python內(nèi)置模塊ConfigParser實(shí)現(xiàn)配置讀寫(xiě)功能的方法

    Python內(nèi)置模塊ConfigParser實(shí)現(xiàn)配置讀寫(xiě)功能的方法

    這篇文章主要介紹了Python內(nèi)置模塊ConfigParser實(shí)現(xiàn)配置讀寫(xiě)功能的方法,涉及Python使用ConfigParser模塊進(jìn)行配置讀、寫(xiě)、修改、刪除等操作的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2018-02-02
  • Python中的pygal安裝和繪制直方圖代碼分享

    Python中的pygal安裝和繪制直方圖代碼分享

    這篇文章主要介紹了Python中的pygal安裝和繪制直方圖代碼分享,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • 快速入手Python字符編碼

    快速入手Python字符編碼

    本文不談復(fù)雜的理論,就經(jīng)驗(yàn)教大家字符處理八字真言:確定編碼,同類(lèi)交互。教大家快速戰(zhàn)勝Python字符編碼。
    2016-08-08
  • Python讀取Excel一列并計(jì)算所有對(duì)象出現(xiàn)次數(shù)的方法

    Python讀取Excel一列并計(jì)算所有對(duì)象出現(xiàn)次數(shù)的方法

    這篇文章主要給大家介紹了關(guān)于Python讀取Excel一列并計(jì)算所有對(duì)象出現(xiàn)次數(shù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • 利用pandas合并多個(gè)excel的方法示例

    利用pandas合并多個(gè)excel的方法示例

    這篇文章主要介紹了利用pandas合并多個(gè)excel的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Python面向?qū)ο笕筇卣?封裝、繼承、多態(tài)

    Python面向?qū)ο笕筇卣?封裝、繼承、多態(tài)

    這篇文章主要介紹了Python面向?qū)ο笕筇卣?封裝、繼承、多態(tài),下面文章圍繞Python面向?qū)ο笕筇卣鞯南嚓P(guān)資料展開(kāi)具體內(nèi)容,需要的朋友可以參考一下,希望對(duì)大家有所幫助
    2021-11-11
  • python處理excel繪制雷達(dá)圖

    python處理excel繪制雷達(dá)圖

    這篇文章主要為大家介紹了python處理excel繪制雷達(dá)圖的相關(guān)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Python時(shí)間管理黑科技之datetime函數(shù)詳解

    Python時(shí)間管理黑科技之datetime函數(shù)詳解

    在Python中,datetime模塊是處理日期和時(shí)間的標(biāo)準(zhǔn)庫(kù),它提供了一系列功能強(qiáng)大的函數(shù)和類(lèi),用于處理日期、時(shí)間、時(shí)間間隔等,本文將深入探討datetime模塊的使用方法,感興趣的可以了解下
    2023-08-08
  • python如何代碼集體右移

    python如何代碼集體右移

    在本篇文章里小編給各位分享的是一篇關(guān)于python如何代碼集體右移的相關(guān)知識(shí)點(diǎn)文章,需要的朋友們可以學(xué)習(xí)下。
    2020-07-07
  • python多進(jìn)程實(shí)現(xiàn)進(jìn)程間通信實(shí)例

    python多進(jìn)程實(shí)現(xiàn)進(jìn)程間通信實(shí)例

    這篇文章主要介紹了python多進(jìn)程實(shí)現(xiàn)進(jìn)程間通信實(shí)例,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11

最新評(píng)論