01背包問題-通俗易懂

尊重勞動成果郑现,轉(zhuǎn)載請注明

github地址:
https://github.com/arkulo56/thought/blob/master/software/algorithm/%E7%AE%97%E6%B3%95---01%E8%83%8C%E5%8C%85%E9%97%AE%E9%A2%98.md


有編號為a粗梭、b、c、d、e的5件物品护戳,他們的重量分別是2首懈、2绊率、6、5究履、4滤否,他們的價值分別是6、3最仑、5藐俺、4、6泥彤,現(xiàn)在給你一個承重為10的背包欲芹,如何讓背包里裝的物品擁有最大的價值?吟吝?

一菱父、讓我們先用現(xiàn)實生活來還原一下這個場景:

去出差,襯衫剑逃、西服浙宜、領(lǐng)帶、剃須刀...都已經(jīng)裝進包里了蛹磺,手里拿著ipad在猶豫帶不帶(因為包已經(jīng)裝不下了)粟瞬?

1)第一種情況:不帶了,包就這么大萤捆,現(xiàn)在包里的東西出差就夠用了裙品!

2)第二種情況:必須要帶,因為ipad里有重要的ppt俗或,那就只能在包里預(yù)留出ipad空間市怎,看看剩下的空間怎么擺放那些必須要帶的東西!

到底怎么做才是最合理(價值最大化)蕴侣?#####
二、一些數(shù)學(xué)的東西

n代表東西的數(shù)量臭觉、c代表包的最大承重昆雀、Wi是第i件物品的重量、Pi是第i件物品的價值蝠筑、F[i,j]是最大價值(i個物品放入承重j的包)

那真實場景中的問題用數(shù)學(xué)的方式來表達狞膘,如果要求F[i,j]的最大值,則要看這兩種 狀態(tài)

第一種情況(不帶):F[i-1,j]
第二種情況(帶):F[i-1,j-Wi]+Pi (j>= Wi) (在背包中給ipad預(yù)留空間Wi,剩下的i-1件物品重新擺放什乙,最后在加上ipad的價值Pi)

那什么才是最合理挽封?也就是價值最大化?那就是看這兩種情況哪種更有利于我出差臣镣! 狀態(tài)轉(zhuǎn)換方程

F[i,j] = MAX(F[i-1,j], F[i-1,j-Wi]+Pi)

是不是悟出了些規(guī)律辅愿,最大值取決于ipad裝與不裝智亮,同時也取決于之前的i-1個物品!

三点待、接下來請看看這張圖阔蛉,先明白原理

<img src="https://raw.githubusercontent.com/arkulo56/thought/master/images/algorithm/beibao.png" width="600" />

有了這張圖和上面總結(jié)的公式,我們就可以很清晰的理解01背包算法了

  1. e2單元格:當(dāng)只有一件物品e癞埠,包的容量是2時状原,裝不進去,所以最大值為0
  2. a8單元格:物品包括a苗踪、b颠区、c、d通铲、e毕莱,容量為8時,F(xiàn)[i-1,j]=F[b,8]=9测暗,F(xiàn)[i-1,j-Wi]+Pi=F[b,6]+6=9+6=15央串,兩種情況取最大值,因此這里的最大值是15
  3. 其他單元格依此類推...
五碗啄、代碼代碼

還沒有寫质和,稍后補充...

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市稚字,隨后出現(xiàn)的幾起案子饲宿,更是在濱河造成了極大的恐慌,老刑警劉巖胆描,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件瘫想,死亡現(xiàn)場離奇詭異,居然都是意外死亡昌讲,警方通過查閱死者的電腦和手機国夜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來短绸,“玉大人车吹,你說我怎么就攤上這事〈妆眨” “怎么了窄驹?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長证逻。 經(jīng)常有香客問我乐埠,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任丈咐,我火速辦了婚禮瑞眼,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘扯罐。我一直安慰自己负拟,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布歹河。 她就那樣靜靜地躺著掩浙,像睡著了一般。 火紅的嫁衣襯著肌膚如雪秸歧。 梳的紋絲不亂的頭發(fā)上厨姚,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機與錄音键菱,去河邊找鬼谬墙。 笑死,一個胖子當(dāng)著我的面吹牛经备,可吹牛的內(nèi)容都是我干的拭抬。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼侵蒙,長吁一口氣:“原來是場噩夢啊……” “哼造虎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起纷闺,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤算凿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后犁功,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體氓轰,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年浸卦,在試婚紗的時候發(fā)現(xiàn)自己被綠了署鸡。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡限嫌,死狀恐怖靴庆,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情萤皂,我是刑警寧澤撒穷,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布匣椰,位于F島的核電站裆熙,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜入录,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一蛤奥、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧僚稿,春花似錦凡桥、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蠢络,卻和暖如春衰猛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背刹孔。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工啡省, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人髓霞。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓卦睹,卻偏偏與公主長得像,于是被迫代替她去往敵國和親方库。 傳聞我的和親對象是個殘疾皇子结序,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,044評論 2 355

推薦閱讀更多精彩內(nèi)容