指数麻烦

时间:2017-04-30 20:00:20

标签: dynamic-programming knapsack-problem indices

我正在编写最大值背包算法。它接受带有值和成本的Items的Knapsack对象。我声明了一个用于计算最大值的2D数组。对于基本情况,我将第0行的值设置为0,将第0列的值设置为0.当我在背包中抓取一个项目时遇到麻烦,因为当我想抓住第0个项目时,我真的抓住了第一个项目在背包中我因此在2D阵列中得到错误的值。有人可以查看我的代码,看看我错过了什么吗?

public static double MaximumKnapsack(Knapsack knapsack) {
    int numItems = knapsack.getNumOfItems();
    int budget = (int) knapsack.getBudget();
    double[][] DP = new double[numItems+1][budget+1];

    boolean taken = false;
    for (int i = 0; i < numItems + 1; i++) {
        for (int b = 0; b < budget + 1; b++) {
            if (i == 0 || b == 0) {
                DP[i][b] = 0;
            }
            else
            {
                Item item = knapsack.getItem(i);
                if (item.getCost() > b) {
                    DP[i][b] = DP[i-1][b];
                }
                else
                {
                    DP[i][b] = Math.max(DP[i-1][b-(int) item.getCost()] + item.getValue(),
                                        DP[i-1][b]);
                    if (DP[i][b] == DP[i-1][b-(int) item.getCost()] + item.getValue() && item.getCost() != 0.0) {
                        taken = true;
                    }
                }
            }
        }
        taken = false;
    }
    return DP[numItems][budget];
}

1 个答案:

答案 0 :(得分:0)

我认为问题在于

Item item = knapsack.getItem(i);

因为你的循环将从i = 1开始。你应该使用:

Item item = knapsack.getItem(i-1);