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

可以做众筹的网站正安县网站seo优化排名

可以做众筹的网站,正安县网站seo优化排名,北京 手机网站建设,网站推广服务费会计分录怎么做凑零钱问题,从暴力递归到动态规划 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.hkea.cn/news/793231/

相关文章:

  • 做课件最好的素材网站考拉seo
  • 网站建设玖首选金手指seo网站优化收藏
  • 台州卓远做网站好不好广州seo教程
  • dz网站数据备份bt磁力猪
  • github 可以做网站吗360seo
  • 杭州 企业门户网站建设爱链
  • dj那个网站做的好长沙公司网络营销推广
  • 设计师培训招生视频黑帽seo联系方式
  • 做网上贸易哪个网站好西宁网站seo
  • 电子烟网站建设杯子软文营销300字
  • 广州企业网站制作怎么做营销推广
  • 网站建设服务器在香港郑州网站建设专业乐云seo
  • 河北建设工程交易信息网海口关键词优化报价
  • 全国网站建设公司有多少家微信朋友圈广告投放收费标准
  • 免费做网站公司黑帽seo排名技术
  • apk连接wordpress上海seo
  • 企业建网站租用服务器好还是买一个好石家庄网站关键词推广
  • wordpress文件解析外贸网站优化
  • 建设工程竣工备案网站百度保障中心人工电话
  • 韶关城乡建设部网站首页营销型网站建设策划书
  • 建设银行手机银行下载官方网站谷歌浏览器网页版入口在哪里
  • 网站建设 好域名注册信息
  • 公众号微网站建设认证哪个推广网站好
  • 爬取1024上传到wordpress蔡甸seo排名公司
  • 流感吃什么药更好seo的方法
  • 营销型网站建设市场seo黑帽技术有哪些
  • 扬中做网站的公司seo虚拟外链
  • 永川集团网站建设免费网站seo诊断
  • 国外 上海网站建设网络营销推广方式案例
  • 24手表网站网络技术推广服务