java - 查找前 k 个背包
问题描述
我得到了背包问题的一个特例,其中权重等于值。我的目标是使用 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, 120, 102, 12]
}
}
解决方案
推荐阅读
- ruby - 如何在 Trailblazer 的 Reform::Form 中验证查询参数?
- django - 如何比较两个 Django 模型并在第三个模型中显示答案
- c# - 使用动作委托更新 VB.NET 中的进度条
- keycloak - 用于获取 Keycloak 用户数据的 REST API 详细信息
- javascript - 如何从 HTML 代码中下载 div 元素
- arrays - 在嵌套数组上显示 onclick
- reactjs - 无法使 React 路由器 dom 工作,“InvalidCharacterError”
- jquery - ajax替换表中的数据后DataTable排序不起作用
- javascript - Monorepo 中的对等依赖关系
- phpstorm - PhpStorm - 使用本地历史重建项目(删除所有项目文件后)?