Leetcode322.零钱兑换(HOT100)

链接

代码:

cpp 复制代码
class Solution {
public:
    int coinChange(vector<int>& coins, int amount) {
        vector<int> dp(amount+1,amount+1);//要兑换amount元硬币,我们就算是全选择1元的硬币,也不过是amount个,所以初始化amount+1(超过最坏答案即可
        dp[0] = 0;//要兑换0面值硬币需要硬币个数为0
        for(int i = 1;i<=amount;i++){
            for(int j = 0;j<coins.size();j++){
                if(i-coins[j]>=0)
                    dp[i] = min(dp[i],dp[i-coins[j]]+1);
            }
        }
        if(dp[amount]==amount+1)//如果这个位置的值与初始化的相同,那么说明,这里的值没别更新过,说明解不存在
            return -1;
        else
            return dp[amount];
    }
};

题解:

要解决这个问题,我们得模拟一下人类看到这个问题是怎么解决的?
比如coins[] = 1 3 4 5 amount = 7

要兑换7,我们可以先选一个1,这样我们的目标就变为兑换7-1也就是6了,要兑换6,我们继续选,比如选1,那么问题转为兑换6-1也就是5了,所以我们发现要求出来兑换amount,那么你得先把兑换amount-1,amount-2.........(一直到兑换0需要0个硬币)求出来,从而得到兑换amount。

所以问题转为填表:兑换0需要0个硬币,那么兑换1需要多少硬币?兑换2需要?兑换...........兑换amount需要多少硬币?

所以我们开一个amount+1长的数组,往进填值。

我们还发现:兑换1需要多少硬币这个子问题,我们不能随便选硬币,比如你选择了5面值,这显然错误,所以我们填表的时候要判断:你要兑换的硬币数减去选择的硬币面值<0则什么都不做,>=0才填表。

相关推荐
计算机安禾1 分钟前
【c++面向对象编程】第3篇:类与对象(二):构造函数与析构函数
开发语言·c++·算法
小年糕是糕手2 分钟前
【C++】vector 不踩坑指南:用法、底层实现与迭代器失效解析
c++·算法
SilentSamsara1 小时前
生成器完全指南:`yield` 与惰性求值的工程价值
linux·开发语言·python·算法·机器学习·青少年编程
玛卡巴卡ldf1 小时前
【LeetCode 手撕算法】(二分查找)搜索插入位置、搜索二维矩阵、查找数组相同的所有位置、搜索旋转排序数组、旋转升序数组的最小值
数据结构·算法·leetcode
谷雨不太卷8 小时前
进程的状态码
java·前端·算法
散峰而望9 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
躺不平的理查德9 小时前
时间复杂度与空间复杂度备忘录
数据结构·算法
yaki_ya9 小时前
yaki-C语言:从概念基础到内存解析---数组(array)完全指南
java·c语言·算法
刃神太酷啦9 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode
挽星安10 小时前
代码随想录算法训练营第五十天|卡码网 99 岛屿数量、卡码网 100 最大岛屿的面积
算法