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

兑换零钱(一)

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

全部评论

相关推荐

2025年初,新的一年开始,我给自己暗暗打气,发誓今年一定要拿到offer。如今2025年即将结束,找工作仍然没有任何水花,如今的失意和落魄和年初信心满满的姿态形成鲜明对比,想必也是因为被社会毒打,认清现实了吧。先分享一下贴主的背景,本人女,本科末流985文科专业,后来保送到华五,成绩一直是班级第一,有过国奖,实习有多段头部大厂经历。发贴的直接原因是今天华为面试挂,在反思中有很多复杂的想法,包括对自身能力的怀疑、对面试官所提问题的不解、对大环境的无奈。贴主是一个说话温柔、不喜欢咄咄逼人、有点社恐的人(基本上算是人们眼中对小女生的刻板印象,所以在历次群面中基本全挂(看到大家争抢当leader、t...
在找内推的小虾米:感觉这一段经历和我好像啊,前段时间面了很多车企,面试项目经历各种被拷打,大多数都没过一面,最有希望拿offer的一个终面挂了把我干破防了,打电话给爸妈哭了一个多小时才缓过来。我也开始否定自己,否定自己的一切,包括性格,能力,成长经历。。。最后面了深圳的某家公司,面试官人都挺友好,提的问题有深度但找到切入点 ,最后hr也按岗位最高的标准给的offer,我才发现自己并没有这么不堪,只是我的能力和经验和之前的岗位要求不那么符合而已。帖主一定不要灰心,招聘的窗口期还有很长很长,保持自信扬长避短,一定有企业能发现你的闪光点,祝好。
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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