题解 | #兑换零钱(一)#

兑换零钱(一)

https://www.nowcoder.com/practice/3911a20b3f8743058214ceaa099eeb45

#include <algorithm>
#include <vector>
class Solution {
  public:
    int minMoney(vector<int>& arr, int aim) {
        if (!aim) return 0;
        if (arr.empty()) return -1;
        int lenarr = arr.size(), minarr = *min_element(arr.begin(), arr.end());
        vector<int> dp(aim, 0);
        int tmp;
        for (int i = 0; i < aim; i++) {
            if (i + 1 < minarr) { //小于最小货币面值
                dp[i] = -1;
            } else {
                tmp = (1 << 31) - 1; //int型最大值
                for (int j = 0; j < lenarr; j++) {
                    if (i + 1 == arr[j]) { //等于所给面值之一,即只需1张货币
                        dp[i] = 1;
                        break;
                    }
                    if (i - arr[j] >= 0) { 
                        if (dp[i - arr[j]] != -1) { //可以在前面记录的最少货币数基础上加一张货币
                            dp[i] = dp[i - arr[j]] + 1 < tmp ? dp[i - arr[j]] + 1 : tmp;
                            tmp = dp[i];
                        }
                    }
                }
                if (dp[i] == 0) { //不可兑换
                    dp[i] = -1;
                }
            }
        }
        return dp[aim - 1];
    }
};

全部评论

相关推荐

牛客977679609号:感觉你会的东西还挺多的但简历一般都不这样写,建议只写一页,教育经历只留学校,导师单位啥的全去了,作品展示和自我评价都去了,科研成果写在所获荣誉里,项目保留,浓缩成一页。
点赞 评论 收藏
分享
你是来当牛马的吧:行了,照片拍完了,让大家都回工位吧
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务