题解 | #最小邮票数#动态规划

最小邮票数

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;
}

全部评论

相关推荐

赏个offer求你了:友塔HR还专门加我告诉我初筛不通过😂
点赞 评论 收藏
分享
程序员猪皮:看不到八股什么意思
点赞 评论 收藏
分享
11-22 16:49
已编辑
北京邮电大学 Java
美团 质效,测开 n*15.5
点赞 评论 收藏
分享
评论
1
收藏
分享
牛客网
牛客企业服务