第26863题 单选
针对01背包一维动态规划实现代码,判断下列说法正确的是哪一项?

给定n个物品和一个最大承重为W的背包,每个物品有一个重量和价值,每个物品只能选择放或不放。目标是选择若干个物品放入背包,使得总价值最大,且总重量不超过W。对应的实现代码如下:

def knapsack1D(W: int, wt: list[int], val: list[int], n: int) -> int:
    dp = [0] * (W + 1)

    for i in range(n):
        for w in range(W, wt[i] - 1, -1):
            dp[w] = max(dp[w], dp[w - wt[i]] + val[i])

    return dp[W]
A

该算法不能处理背包容量为0的情况

B

外层循环i遍历背包容量,内层遍历物品

C

从大到小遍历背包容量w是为了避免重复使用同一物品

D

这段代码计算的是最小重量而非最大价值

提交0次 正确率0.00%
答案解析