【动态规划】兑换零钱(一)

求解代码

java 复制代码
public int minMoney (int[] arr, int aim) {
        int[] dp = new int[aim+1];
        Arrays.fill(dp, Integer.MAX_VALUE);

        dp[0]=0;

        for(int i=0;i<arr.length;i++){
            for(int j=arr[i];j<=aim;j++){
                if(dp[j-arr[i]]!=Integer.MAX_VALUE){
                    dp[j]=Math.min(dp[j-arr[i]]+1,dp[j]);
                }
                
            }
        }

        return dp[aim]==Integer.MAX_VALUE?-1:dp[aim];
    }

小贴士

dp[j] 表示的是凑出金额j所需的最少硬币数

相关推荐
Sarvartha2 小时前
顺序表笔记
算法
宵时待雨2 小时前
数据结构(初阶)笔记归纳6:双向链表的实现
c语言·开发语言·数据结构·笔记·算法·链表
狐572 小时前
2026-01-20-LeetCode刷题笔记-3314-构造最小位运算数组I
笔记·算法·leetcode
0和1的舞者2 小时前
非力扣hot100-二叉树专题-刷题笔记(一)
笔记·后端·算法·leetcode·职场和发展·知识
FMRbpm2 小时前
树的练习7--------LCR 052.递增顺序搜索树
数据结构·c++·算法·leetcode·深度优先·新手入门
技术民工之路2 小时前
MATLAB线性方程组,运算符、inv()、pinv()全解析
线性代数·算法·matlab
一起努力啊~2 小时前
算法刷题--双指针法
算法
Coovally AI模型快速验证2 小时前
从“单例模仿”到“多面融合”,视觉上下文学习迈向“团队协作”式提示融合
人工智能·学习·算法·yolo·计算机视觉·人机交互
明洞日记2 小时前
【软考每日一练007】位图计算与内存管理深度全解
c++·算法·ai·操作系统·进程