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

做下载网站上门做网站

做下载网站,上门做网站,韶关市网站建设公司,潍坊做网站哪个公司好凑零钱问题,从暴力递归到动态规划 leetcode 322 题 零钱兑换暴力递归(这个会超时,leetcode 跑不过去)递归缓存动态规划优化暴力递归动态规划专题 leetcode 322 题 零钱兑换 322 零钱兑换 - 可以打开链接测试 给你一个整数数组 c…

凑零钱问题,从暴力递归到动态规划

  • leetcode 322 题 零钱兑换
  • 暴力递归(这个会超时,leetcode 跑不过去)
  • 递归+缓存
  • 动态规划优化暴力递归
  • 动态规划专题

leetcode 322 题 零钱兑换

322 零钱兑换 - 可以打开链接测试

给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。
计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。
你可以认为每种硬币的数量是无限的。

示例 1:
输入:coins = [1, 2, 5], amount = 11
输出:3
解释:11 = 5 + 5 + 1

示例 2:
输入:coins = [2], amount = 3
输出:-1

示例 3:
输入:coins = [1], amount = 0
输出:0

提示:
1 <= coins.length <= 12
1 <= coins[i] <= 231 - 1
0 <= amount <= 104

暴力递归(这个会超时,leetcode 跑不过去)

解题思路:
凑零钱就是每次选择一种面值的零钱后,然后递归下面所有选择的可能,
我们去递归遍历所有可能性,然后选择一个最少的可能。

代码演示:

 int coinChange(int[] coins, int amount) {if(amount == 0){return 0;}return process(coins,amount);}public int process(int[]coins,int amount){//base caseif(amount == 0){return 0;}//base case if(amount < 0){return -1;}int res = Integer.MAX_VALUE;for(int c : coins){int num = process(coins,amount - c);//当前这种情况无法完成,继续递归if(num == -1){continue;}//比较更新保存最小值res = Math.min(res,num + 1);}return res == Integer.MAX_VALUE ? -1 : res;}

在这里插入图片描述

递归+缓存

思路:
缓存就是为了减少重复计算,这里面的重复计算,很明显就是剩余要凑出来的零钱。
用数组进行缓存。
对上面暴力递归 稍加改造

代码演示

class Solution {int[]ans;int coinChange(int[] coins, int amount) {if(amount == 0){return 0;} ans = new int[amount + 1];return process(coins,amount);}public int process(int[]coins,int amount){if(amount == 0){return 0;}if(amount < 0){return -1;}if(ans[amount] != 0){return ans[amount];}int res = Integer.MAX_VALUE;for(int c : coins){int num = process(coins,amount - c);if(num == -1){continue;}res = Math.min(res,num + 1);}ans[amount] = res == Integer.MAX_VALUE ? -1 : res;return  ans[amount];}
}

在这里插入图片描述

动态规划优化暴力递归

动态规划是自底向上的求出所有值,保存在缓存里,然后去拿,
这个和递归加缓存的区别就是,第二种还是自顶向下计算,缓存只是为了去除重复计算,
动态规划则是直接把整个缓存表都填满,需要什么去拿什么
之所以这样,是为了更难的题,有了这个表格后,可以做很多操作,
就目前这个题,递归加缓存和动态规划并没有实质的提升.

代码:

   int coinChange(int[] coins, int amount) {int[]dp = new int[amount + 1];//初始化为amount + 1 因为最大值也就是amount 全是一元凑出来。Arrays.fill(dp, amount + 1);//base case dp[0] = 0;for(int i = 0; i < dp.length;i++){for(int coin : coins){if(i - coin < 0){continue;}dp[i] = Math.min(dp[i] ,dp[i - coin] + 1);}}return (dp[amount] == amount + 1) ? -1 : dp[amount];}

在这里插入图片描述

动态规划专题

斐波那契数列-从暴力递归到动态规划

走到指定位置有多少种方式-从暴力递归到动态规划

http://www.yayakq.cn/news/183667/

相关文章:

  • 建立个大型网站需要多少投入建筑工程公司资质
  • 自适应网站建设优化建站科技部网站支持湖南建设创新型省份
  • 两学一做 专题网站为什么网站不见了
  • thinkphp做企业网站广州网络推广公司电话
  • 做卡贴质量好的网站利用数据库修改wordpress密码
  • 互联网运营平台嘉兴seo公司网站
  • 企业网站建设博客论坛wordpress页面内导航
  • 赣州网站建设如何公司黄页是什么东西
  • 可以做闪图的网站大理建设工程招聘信息网站
  • 茂名建站公司模板网站平均停留时间
  • 河北网站seo地址做网站及APP
  • 个人网站开发实例设计网站什么叫空间不稳定
  • psd做网站切片广州市安全教育平台app下载
  • 哪个网站可以看一级a做爰片t长沙如何优化排名
  • 建设网站虚拟现实技术网站如何paypal支付
  • 山西网络网站建设销售公司免费企业建站系统排名
  • 苏宁易购网站建设情况关键词排名
  • 成都网站营销推广公司龙华新区网站制作
  • 生成手机网站wordpress固定链接无法访问
  • 朱晓宇 大庆 seo 网站建设 北京如何用php做网站
  • 临海最火自适应网站建设wordpress菜单优化插件
  • 网站建设域名有哪些类型沧州企业网站专业定制
  • 个人可以建购物网站吗新野微网站建设
  • 讯杰网站建设小学做试卷的网站
  • 来宾北京网站建设商品网站建设
  • 学做网站论坛教程做网络竞拍的网站需要什么
  • 个人缴纳养老保险电影网站怎么做优化
  • 陕西网站开发企业加盟网站需要怎么做
  • 建设银行明细网站能查多久北京标本制作
  • 网站备案不能访问互联网运营模式有哪几种