文章

17

粉丝

177

获赞

2

访问

118.3k

头像
C++,曾经尝试使用C语言,但是为什么memset数组初始化为INT_MAX会有问题
P1164 清华大学上机题
发布于2021年9月26日 14:42
阅读数 6.3k

#include<iostream>
#include<algorithm>
#include<climits>
#include<vector>
using namespace std;
int main(){
    
    int values[20];
    vector<int> dp(100, INT_MAX);
    
    int M, N;
    while(cin >> M >> N){
        dp[0] = 0;
        for (int i = 0; i < N;i++)
            cin >> values[i];
        for (int i = 0; i < N;i++){
            for (int j = M; j >= values[i];j--)
            {
                if(dp[j - values[i]] != INT_MAX)
                    dp[j] = min(dp[j], dp[j - values[i]] + 1);
            }
        }
        if(dp[M] != INT_MAX)
            cout << dp[M] << endl;
        else
            cout << 0 << endl;

        for (int i = 0; i < 100;i++)
            dp[i] = INT_MAX;
    }
    
}

 

登录查看完整内容


登录后发布评论

暂无评论,来抢沙发