当前位置: 首页 > news >正文

零钱兑换00

题目链接

零钱兑换

题目描述

注意点

  • 如果没有任何一种硬币组合能组成总金额,返回 -1
  • 可以认为每种硬币的数量是无限的

解答思路

  • 动态规划从总金额1开始推出目标金额所需的最少硬币个数,任意某个金额所需的最少硬币个数可以由当前金额减去每种面额的硬币,通过前置金额所需的最少硬币个数加1就是当前金额所需的最少硬币个数

代码

class Solution {public int coinChange(int[] coins, int amount) {int[] dp = new int[amount + 1];for (int i = 1; i <= amount; i++) {int minNum = -1;for (int coin : coins) {if (i -  coin < 0 || dp[i - coin] < 0) {continue;}minNum = minNum < 0 ? dp[i - coin] : Math.min(minNum, dp[i - coin]);}dp[i] = minNum < 0 ? minNum : (minNum + 1);}return dp[amount];}
}

关键点

  • 动态规划的思想
http://www.lryc.cn/news/162989.html

相关文章:

  • JavaScipt中如何实现函数缓存?函数缓存有哪些场景?
  • android studio的Android Drawable Preview
  • 基于云计算的区域LIS系统系统源码
  • VR农学虚拟仿真情景实训教学演示
  • sklearn中make_blobs方法:聚类数据生成器
  • Win11自带微软输入法怎么输入π及其他希腊字母
  • 关于MyBatisPlus框架下出现xml里面定义的方法无法被正确识别以及提示调用mysql存储过程时参数无效的问题
  • vscode路径别名文件跳转解决办法
  • layui 富文本编辑器layedit 以及 图片转base64前端页面显示
  • 服务器给前端实时推送数据轻量化解决方案eventSource+Springboot
  • 数据结构与算法:数据结构基础
  • virtualbox虚拟机中安装FreeDOS系统和DJGPP编译环境
  • JAVASE事件监听
  • ubuntu14.04改静态ip
  • “文件的上传与下载:实现与优化“
  • uboot顶层Makefile前期所做工作说明三
  • Mysql树形表的两种查询方案(递归与自连接)
  • text-align和text-align-last的属性值
  • SpringMVC的注解、参数传递、页面跳转
  • OAK相机:启动报错X_LINK_DEVICE_NOT_FOUND
  • Python异常处理——走BUG的路,让BUG无处可走
  • 如何解决iOS打包工具AppUploader登录权限问题?
  • leetcode分类刷题:基于数组的双指针(四、小的移动)
  • eclipse
  • VIT中的einops包详解
  • 目标检测笔记(十三): 使用YOLOv5-7.0版本对图像进行目标检测完整版(从自定义数据集到测试验证的完整流程))
  • 【数据结构】设计环形队列
  • 无涯教程-JavaScript - COUPDAYSNC函数
  • python 随机生成emoji表情
  • python关闭指定进程以excel为例