当前位置:网站首页>0-1 knapsack problem
0-1 knapsack problem
2022-07-07 23:35:00 【A little dog】
0-1 knapsack
0 - 1 knapsack problem
1. Looking for maximum value
The standard 01 knapsack 
What is the maximum value of filling ?
- The solution to violence is dps Deep backtracking algorithm ( Load the backpack And no backpack )
- Non violent use dp The equation is dynamically recursive
1.1 Definition dp Array dp[i][j]
i Indicates the column length , That is, different objects appear
j Indicates the president , But the line at this time , For the possibility of loading different weights , in other words 0 It's also possible not to install , therefore (j = Maximum weight + 1)
And the corresponding dp[i][j] There is value .

1.2 Two dimensional array implementation
import java.util.*;
/** * @author JMWANG */
import java.io.*;
class Good {
// value
int value;
// weight
int weight;
Good(int v, int p) {
this.value = v;
this.weight = p;
}
Good() {
}
public void setValue(int v) {
this.value = v;
}
public void setWeight(int p) {
this.weight = p;
}
}
public class Main {
public static void main(String[] args) throws IOException {
// Maximum backpack weight
int n = 4;
// Build items
List listGood = new ArrayList();
listGood.add(new Good(15, 1));
listGood.add(new Good(20, 3));
listGood.add(new Good(30, 4));
//dp Recursive equation construction
int[][] goods = new int[listGood.size()][n + 1];
// for (int i = 0; i < goods.length; i++) {
// System.out.println(Arrays.toString(goods[i]));
// }
dp(n, goods, listGood);
System.out.println(goods[listGood.size() - 1][n]);
}
public static void dp(int N, int[][] dp, List<Good> listGood) {
// The relationship between the upper and lower levels
//dp[i][j] = max(listGood.get(i),)
for (int i = 0; i < listGood.size(); i++) {
for (int j = 0; j < N + 1; j++) {
// initialization dp equation
if (j == 0) {
dp[i][j] = 0;
continue;
}
if (i == 0) {
dp[i][j] = listGood.get(i).weight <= N ? listGood.get(i).value : 0;
continue;
}
// If at present weight j < The weight of the current item , Just directly transfer the weight of the upper layer down
if (j < listGood.get(i).weight) dp[i][j] = dp[i - 1][j];
// If at present weight j >= The weight of the current item , We need to compare
// The value of the vertical layer is greater still On the left + The value of the current item is greater
else {
dp[i][j] = Math.max(dp[i - 1][j], dp[i - 1][j - listGood.get(i).weight] + listGood.get(i).value);
}
LookDP(dp);
System.out.println("______________________________");
}
}
}
public static void LookDP(int[][] goods) {
for (int i = 0; i < goods.length; i++) {
for (int j = 0; j < goods[i].length; j++) {
System.out.print(goods[i][j] + " ");
}
System.out.println();
}
}
}
1.3 One dimensional array implementation
public static void testWeightBagProblem(int N, List<Good> listGood){
int len = listGood.size();
// Definition dp Array ,dp[j] Indicates that the backpack capacity is j when , The greatest value you can get
int[] dp = new int[N +1];
// traversal order : Go through the items first , Then traverse the backpack capacity
for(int i=0;i<len;i++){
for(int j=N;j>=listGood.get(i).weight;j--){
System.out.println(Arrays.toString(dp));
dp[j] = Math.max(dp[j], dp[j-listGood.get(i).weight]+listGood.get(i).value);
}
}
System.out.println(Arrays.toString(dp));
System.out.println(dp[N]);
}
Please correct me if there is any mistake
边栏推荐
- Solve the problem of duplicate request resource paths /o2o/shopadmin/o2o/shopadmin/getproductbyid
- 13、 System optimization
- 【7.5】15. 三数之和
- 包装行业智能供应链S2B2B商城解决方案:开辟电商消费新生态
- PHP uses Alibaba cloud storage
- [untitled]
- Given an array, such as [7864, 284, 347, 7732, 8498], now you need to splice the numbers in the array to return the "largest possible number."
- Map operation execution process
- B_QuRT_User_Guide(37)
- In the field of software engineering, we have been doing scientific research for ten years!
猜你喜欢

Solution of intelligent supply chain collaboration platform in electronic equipment industry: solve inefficiency and enable digital upgrading of industry

Home appliance industry channel business collaboration system solution: help home appliance enterprises quickly realize the Internet of channels

建筑建材行业SRM供应商云协同管理平台解决方案,实现业务应用可扩展可配置

2022第六季完美童模陕西总决赛圆满落幕

Markdown

LDO穩壓芯片-內部框圖及選型參數

UE4_ Use of ue5 blueprint command node (turn on / off screen response log publish full screen display)

Add data analysis tools in Excel

在软件工程领域,搞科研的这十年!

Lm12 rolling heikin Ashi double K-line filter
随机推荐
What if once again forgets the login password of raspberry pie? And you don't have a monitor yet! Today, I would like to introduce a method
B_ QuRT_ User_ Guide(40)
Fibonacci number of dynamic programming
Mysql索引优化实战二
The efficient s2b2c e-commerce system helps electronic material enterprises improve their adaptability in this way
SAP HR奖罚信息导出
LeeCode -- 6. Z 字形变换
SQL database execution problems
Extended tree (I) - graphic analysis and C language implementation
The 19th Zhejiang Provincial College Programming Contest VP record + supplementary questions
Sequence of entity layer, Dao layer, service layer and controller layer
2022第六季完美童模陕西总决赛圆满落幕
云原生正在吞噬一切,开发者该如何应对?
UE4_ Ue5 panoramic camera
【7.5】15. 三数之和
Summary of SQL single table query 2020.7.27
USB (XVIII) 2022-04-17
进度播报|广州地铁七号线全线29台盾构机全部完成始发
MySQL Index Optimization Practice I
家用电器行业渠道商协同系统解决方案:助力家电企业快速实现渠道互联网化