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

兑换零钱(一)

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

class Solution {
  public:
    int minMoney(vector<int>& arr, int aim) {
        if (!aim) return 0;
        if (arr.empty()) return -1;
        int lenarr = arr.size();
        vector<int> dp(aim, 1e9);
        for (int j = 0; j < lenarr; j++) {
            for (int i = arr[j] - 1; i < aim; i++) { //外循环遍历arr,内循环遍历[arr[j]-1,aim]可以跳过一些小于arr[j]的数
                if (i + 1 == arr[j]) {
                    dp[i] = 1;
                } else {
                    if (i - arr[j] >= 0) {
                        if (dp[i - arr[j]] != -1) {
                            dp[i] = dp[i - arr[j]] + 1 < dp[i] ? dp[i - arr[j]] + 1 : dp[i];
                        }
                    }
                }
            }
        }
        if (dp[aim - 1] == 1e9) {
            dp[aim - 1] = -1;
        }
        return dp[aim - 1];
    }
};

全部评论

相关推荐

27双非本,最近面试被挂麻了面试官说简历内容太简单了,技术栈要单独一行,各位佬有啥建议吗
LZStarV:项目太简单了,你像用什么开发的技术栈没必要写一句话,按点写就好了;有特色的比如说WebSocket、视频流这种狠狠吹,那就好看多了
点赞 评论 收藏
分享
点赞 评论 收藏
分享
未知的命运:大佬这都找不到我还找啥啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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