日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

c++ 多重背包状态转移方程_Python|动态规划关于0-1背包问题

發布時間:2024/7/23 c/c++ 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c++ 多重背包状态转移方程_Python|动态规划关于0-1背包问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文的文字及圖片來源于網絡,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯系我們以作處理

以下文章來源于騰訊云,作者:算法與編程之美

前言

對學算法的同學來說,動態規劃是其必學且較為重要的問題之一;其中0-1背包問題是最經典的動態規劃問題;本博客也主要以動態規劃來解決0-1背包問題。

問題描述

有如下的背包的重量及其所對應的質量,背包的最大承受重量為6kg,試問要怎樣裝入才能使得背包再最大的承受重量的范圍內裝入的物品的質量最大?

動態規劃進行問題分析

首先我們的創一個dp[i][j]的數組,bag[index]數組表示物品的重量與質量;

(bag[index][0]表示重量,bag[index][1]表示質量);其中的i來表示物品,j來表示當前背包所能承受的最大重量;dp[i][j]來表示當前背包重量為j時所能承裝的最大質量,這時我們可以等到一個動態的轉移方程:

dp

方程解析;當我們去遍歷物品的時候我們會分兩種情況,即裝與不裝;

不裝入該物品:dp[i][j]的質量就是上個物品的質量,即就等于dp[i-1][j];i表示物品,就是i-1的質量。

裝入該物品:dp[i-1][j-bag[index][0]]+bag[index][1],i表示當前的第i個物品,i-1表示上一個物品,因為j表示當前背包所能承裝的最大質量,所以j-bag[index][0]表示若要裝入物品,那么必須取上一個物品的背包最大容量(即第i-1個物品)為j-bag[index][0],因為這樣裝入第i個物品剛好裝滿容量為j的背包。

代碼解決

bag, n, dp = [[6,3],[10,1],[5,2],[10,4]], 6, []# bag表示物品的重量與其所對應的質量,n為背包最大容量for i in range(len(bag)): dp.append([0]*(n+1))for i in range(n+1): if i >= bag[0][1]: dp[0][i] = bag[0][0] #第一次遍歷數組將得到第一個物品所對應的最大質量得出for i in range(1,len(bag)): for j in range(n+1): if bag[i][1] <= j: dp[i][j] = max(dp[i-1][j], dp[i-1][j-bag[i][1]]+bag[i][0]) # 取dp[i][j]當前的最大質量print(dp[-1][-1]) # 打印dp最終j=n(背包最大容量)的最大質量

總結

本博客主要講述了如何用動態規劃來解決0-1背包問題;總的來說,0-1背包問題就是經典的動態規劃問題,用dp數組來記憶所需的值來推導相關聯的下一個值即可。

總結

以上是生活随笔為你收集整理的c++ 多重背包状态转移方程_Python|动态规划关于0-1背包问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。