题解 | #最小邮票数#01背包模板题,记住就行。

最小邮票数

https://www.nowcoder.com/practice/83800ae3292b4256b7349ded5f178dd1

#include<iostream>
#include <vector>
#include <climits>
using namespace std;
int main() {
    int m, n;
    while (cin >> m >> n) {
        vector<int> dp(m + 1, INT_MAX);
        dp[0] = 0;
        for (int i = 0; i < n; i++) {
            int value;
            cin >> value;
            for (int j = m; j >= value; j--) {
                if (dp[j - value] != INT_MAX && dp[j - value] + 1 < dp[j]) {
                    dp[j] = dp[j - value] + 1;
                }
            }
        }
        cout << (dp[m] == INT_MAX ? 0 : dp[m]) << endl;
    }
    return 0;
}

全部评论

相关推荐

notbeentak...:孩子,说实话,选择很重要,可能你换一个方向会好很多,但是现在时间不太够了,除非准备春招
点赞 评论 收藏
分享
09-02 11:14
已编辑
四川大学 Java
吴offer选手:这种面试是最烦的,学不到东西,然后还被挂的莫名其妙。之前看到一种说法是面试官如果不想要你了,就会问一些很简单的问题,防止你举报他
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务