找到前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,12]
    }
}

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)