国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - python 貪心算法的實現

python 貪心算法的實現

2020-09-19 23:36Achilles_Heel Python

這篇文章主要介紹了python 貪心算法的實現,幫助大家更好的理解和學習python,感興趣的朋友可以了解下

貪心算法

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

貪心算法不是對所有問題都能得到整體最優解,關鍵是貪心策略的選擇,選擇的貪心策略必須具備無后效性,即某個狀態以前的過程不會影響以后的狀態,只與當前狀態有關。

基本思路

思想

貪心算法的基本思路是從問題的某一個初始解出發一步一步地進行,根據某個優化測度,每一步都要確保能獲得局部最優解。每一步只考慮一個數據,他的選取應該滿足局部優化的條件。若下一個數據和部分最優解連在一起不再是可行解時,就不把該數據添加到部分解中,直到把所有數據枚舉完,或者不能再添加算法停止 。

步驟

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

python 貪心算法的實現

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

例子——硬幣找零

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

python 貪心算法的實現

這里我們的貪心策略為:

先找到最接近a的值,然后對a進行更新,然后進行循環。

代碼實現

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
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))

例子——任務規劃

問題描述:

輸入為任務集合X= [r1,r2,r3,...,rn],每個任務ri,都對應著一個起始時間ai與結束時間bi

要求輸出為最多的相容的任務集。

python 貪心算法的實現

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

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

  1. 先將結束時間最短的任務加入到S中,
  2. 再從剩下的任務的任務中選擇結束時間最短的,且判斷與S集合中的任務是否相容
  3. 若不相容,則換下一個時間最短的任務,并進行比較
  4. 循環,直至X為空。

代碼實現

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
# 任務規劃
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())
# 根據bi進行排序,結束時間早的在前面(冒泡排序)
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 語句可以不寫
    else:
      continue
print(out)

以上就是python 貪心算法的實現的詳細內容,更多關于python 貪心算法的資料請關注服務器之家其它相關文章!

原文鏈接:https://www.cnblogs.com/sunny0824/p/13466341.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美一区二区在线播放 | 能在线观看的黄色网址 | 国产亚洲欧美一区二区 | 欧美午夜一区二区三区免费大片 | 日本久久精品一区 | 在线一级黄色片 | 99久久久无码国产精品 | 亚洲久草| 日韩看片 | 成人国产精品久久久 | 日一区二区 | www.爱色av.com | 天堂色 | 一级毛片免费看 | 91视频导航 | 久久精品成人 | 免费一级毛片 | 免费看黄色片 | 欧州一区二区 | 小视频免费在线观看 | 日韩福利 | 免费又黄又爽又猛的毛片 | 中文在线视频 | 久久久久久亚洲精品中文字幕 | 精品一区二区三 | 久久一二区 | 视频三区 | 成人av在线播放 | 免费观看一区二区三区毛片 | 亚洲视频一区二区三区在线观看 | 最新国产在线视频 | 成人午夜视频在线播放 | 国产精品69久久久久水密桃 | 久久香蕉综合 | 免费在线观看黄色 | www.99re| 操视频网站 | 日本一区二区不卡 | 色五月激情综合网 | 激情一区 | 国产成人久久精品一区二区三区 |