亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:86日期:2022-07-10 17:09:39

貪心算法

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

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

基本思路

思想

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

步驟

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

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

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

例子——硬幣找零

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

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

這里我們的貪心策略為:

先找到最接近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 outa = 36print(shortNum(a))

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

問題描述:

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

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

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

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

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

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

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

# 任務(wù)規(guī)劃from collections import OrderedDicttask = 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 Truefor 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: continueprint(out)

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

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 国产免费一区二区在线看 | 三级黄色免费网站 | 黄色在线观看免费 | 黄色三级视频在线播放 | 黄色在线视频在线观看 | 九九爱精品 | 免费观看一级黄色片 | 午夜网站在线播放 | 薰衣草视频高清在线观看免费 | 免费久草视频 | 国产高清视频一区二区 | 亚洲综合区小说区激情区噜噜 | 222aaa免费| 男女日批视频在线永久观看 | 亚洲国产三级在线观看 | 中文字幕 日韩有码 | 求欧美精品网址 | 亚洲在线日韩 | 一级做片爱性视频免费 | 日本乱中文字幕系列 | 成人精品mv视频在线观看 | 亚洲成人福利在线观看 | 另类av| 久青草国产手机视频免费观看 | 国产成人啪午夜精品网站 | 国产成人99久久亚洲综合精品 | 91视频一区二区 | 中文字幕曰韩一区二区不卡 | 美女va | 精品成人免费播放国产片 | 色综合99 | 98国内自拍在线视频 | 丰满女人毛片免费播放 | 国产精品第1页在线播放 | 免费久草视频 | 中文字幕不卡在线高清 | 午夜免费福利不卡网址92 | 91免费公开视频 | 久久国产区 | 免费观看又色又爽又大高清网站 | 欧美成亚洲 |