题解 | #最小邮票数#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;
}

全部评论

相关推荐

在笔试的大西瓜很矫健:校招数分不用想了,这经历和学历都不够用,大厂更别想,初筛都过不了,说点不好听的小厂数分都进不去(小厂也是假数分),要两个对口实习+3个项目(或者3+2),而且要有含金量才能补一点你的学历劣势。 建议刷实习,社招找数分,校招看运气,能入行业就行,可以运营转数分
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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