【问题标题】:0-1 knapsack dynamic programming solution does not work0-1背包动态规划解法不起作用
【发布时间】:2018-03-05 06:01:25
【问题描述】:

这是在geeks for geeks上找到的0-1背包问题动态规划代码。我已经为自己的测试更改了输入,但它似乎不起作用。最佳解决方案不是第 4 项 (v:10, w:7) 的 1 和第 1 项 (v:1, w:1) 的 3 加起来为 13 吗?当我运行代码并手动执行算法时,结果是 12 和第 2 项和第 4 项。我哪里出错了?

// A Dynamic Programming based solution for 0-1 Knapsack problem
#include<stdio.h>

// A utility function that returns maximum of two integers
int max(int a, int b) { return (a > b)? a : b; }

// Returns the maximum value that can be put in a knapsack of capacity W
int knapSack(int W, int wt[], int val[], int n)
{
int i, w;
int K[n+1][W+1];

// Build table K[][] in bottom up manner
for (i = 0; i <= n; i++)
{
    for (w = 0; w <= W; w++)
    {
        if (i==0 || w==0)
            K[i][w] = 0;
        else if (wt[i-1] <= w)
            K[i][w] = max(val[i-1] + K[i-1][w-wt[i-1]], K[i-1][w]);
        else
            K[i][w] = K[i-1][w];
    }
}

return K[n][W];
}

int main()
{
    int val[] = {1, 2, 5, 10};
    int wt[] = {1, 3, 4, 7};
    int W = 10;
    int n = sizeof(val)/sizeof(val[0]);
    printf("%d", knapSack(W, wt, val, n));
    return 0;
}

【问题讨论】:

    标签: algorithm dynamic knapsack-problem


    【解决方案1】:

    因为这个算法解决了0-1背包问题。

    在这个公式中,每个项目只有一个实例可用。这就是解决方案使用项目一次的原因。

    (也许您正在考虑每件物品的数量不限(或限制)的背包)

    【讨论】:

    • 谢谢哈哈,我知道我得到答案后会觉得自己很愚蠢。
    猜你喜欢
    • 1970-01-01
    • 2018-03-27
    • 2022-01-13
    • 2018-04-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-03-15
    相关资源
    最近更新 更多