问题描述
我有一个背包问题的特例,其中权重等于值。我的目标是使用DP方法为j
(目标重量)打印最W
个最封闭的解决方案。
到目前为止,我只能打印一个结果,但是我没有弄清楚如何有效地跟踪排名靠前的j
解决方案。
package com.gazman.quadratic_sieve.core.poly;
import java.util.ArrayList;
import java.util.List;
class Knapsack {
static List<Integer> knapSack(int W,int[] weights) {
int i,w;
int n = weights.length + 1;
int[][] k = new int[n][W + 1];
for (i = 0; i < n; i++) {
for (w = 0; w <= W; w++) {
if (i == 0 || w == 0) {
k[i][w] = 0;
}
else {
int r = k[i - 1][w];
if (weights[i - 1] <= w) {
int l = weights[i - 1] + k[i - 1][w - weights[i - 1]];
k[i][w] = Math.max(l,r);
} else {
k[i][w] = r;
}
}
}
}
int res = k[n - 1][W];
w = W;
List<Integer> result = new ArrayList<>();
for (i = n - 1; i > 0 && res > 0; i--) {
if (res != k[i - 1][w]) {
result.add(weights[i - 1]);
res = res - weights[i - 1];
w = w - weights[i - 1];
}
}
return result;
}
public static void main(String[] args) {
int[] val = new int[]{12,102,120,280,1000,1200};
int W = 1279;
System.out.println(knapSack(W,val)); // [1000,12]
}
}
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)