第20994题 单选
针对01背包问题的一维动态规划C++实现代码,下列说法正确的是?

给定n个物品和最大承重为W的背包,每个物品有重量wt[i]和价值val[i],且每个物品只能选择放或不放。目标是选择若干个物品放入背包,使得总价值最大且总重量不超过W。关于以下C++代码,说法正确的是:

int knapsack1D(int W, vector<int>& wt, vector<int>& val, int n) {
    vector<int> dp(W+1, 0);
    for (int i = 0; i < n; ++i) {
        for (int w = W; w >= wt[i]; --w) {
            dp[w] = max(dp[w], dp[w - wt[i]] + val[i]);
        }
    }
    return dp[W];
}
A

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

B

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

C

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

D

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