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才填表。

相关推荐
Zero3 小时前
机器学习微积分--(1)核心思想
人工智能·算法·机器学习
有Li3 小时前
一种病理学内容感知变速率学习图像压缩框架 (PathoLIC)/文献速递-多模态应用技术
人工智能·深度学习·算法·计算机视觉·医学生
x_xbx3 小时前
LeetCode:34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
Ricky_Theseus3 小时前
数据库关系代数 - 连接操作
linux·数据库·算法
绿算技术3 小时前
宝辰股份董事长莅临绿算技术调研交流
人工智能·科技·算法
码云数智-园园4 小时前
哈希冲突的解决之道:深入理解哈希表底层原理
算法·哈希算法
qq_416018724 小时前
C++中的模板方法模式
开发语言·c++·算法
天上路人4 小时前
A-59F 多功能语音处理模组在本地会议系统扩音啸叫处理中的技术应用与性能分析
人工智能·神经网络·算法·硬件架构·音视频·语音识别·实时音视频
yang_B6215 小时前
噪声处理方法
大数据·人工智能·算法
菜菜小狗的学习笔记5 小时前
剑指Offer算法题(九)搜索
数据结构·算法·深度优先