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

mac系统可以做数据库网站开发windows优化大师是什么软件

mac系统可以做数据库网站开发,windows优化大师是什么软件,网站模块是什么,专业做数据的网站有哪些凑零钱问题,从暴力递归到动态规划 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.ds6.com.cn/news/3071.html

相关文章:

  • 焦作 网站建设seo学校培训课程
  • 福永网站推广新闻发稿渠道
  • 日本传统颜色 网站2022年最火的关键词
  • 无极ip上海谷歌seo推广公司
  • 衡水做wap网站多少钱网站开发流程
  • 橙子建站是什么软件广州网站建设正规公司
  • 有关房地产开发建设的网站江苏网络推广公司
  • 黄金网站大全免费2023谷歌seo工具
  • 武汉有几个区seo搜索引擎优化营销案例
  • 昌乐网站制作价格搜索引擎推广实训
  • 宜春网站制作公司搜索引擎营销的优缺点
  • 温州建设小学的网站最新长尾关键词挖掘
  • 网站建设工作整改报告深圳网站搜索优化
  • 广州 网站 设计国外seo比较好的博客网站
  • wordpress搭个人博客东莞seo公司
  • 怎么制作网站链接手机长尾关键词排名系统
  • 做h5页面的网站seo技术培训江门
  • 橱柜网站建设公司重庆seo技术分享
  • 网站编辑字体字号合肥seo建站
  • 怎么推广网站平台软文素材网
  • 衡水提供网站设计公司哪家专业google 浏览器
  • 软件学校网站模板下载免费推广平台
  • 17一起做网站童装郑州网站推广方案
  • 常州做网站那家快如何查询百度搜索关键词排名
  • 采集网站后台客户数据自己可以创建网站吗
  • 站群系统的优劣中央新闻今日要闻
  • 食品网站建设实施方案外国黄冈网站推广平台
  • 做简历的网站viso天津百度推广排名
  • 网站是做后台好还是做前台好企业网站怎么建立
  • 漯河企业网站开发网销怎么做才能做好