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

厦门高端网站建设公司湖南现在有什么网站做农副产品

厦门高端网站建设公司,湖南现在有什么网站做农副产品,app立即打开,wordpress4.9主题安装本题链接:. - 力扣(LeetCode) 题目: 思路: 根据题意,这是一道很裸的背包问题,其中这里是返回 背包方案数 的。 我们可以直接推出公式 : dp [ j ] dp[ j - coins[ i ] ] 在我之前…

本题链接:. - 力扣(LeetCode)

题目:

思路:

        根据题意,这是一道很裸的背包问题,其中这里是返回 背包方案数 的。

我们可以直接推出公式 : dp [ j ] += dp[ j - coins[ i ] ]

在我之前做的笔记中,写过具体的背包方案数dp公式,参考我之前的详解即可:dp专题10 目标和 

最后我们再明确一下题目,题目要求是  硬币数量是无限的,说明这是一个 完全背包问题。

完全背包问题 和 01 背包问题区别在于 遍历背包的顺序。

01   背包的  背包 遍历顺序: 逆向。

完全背包的  背包 遍历顺序: 正向。

具体原理是:

背包 逆向 遍历的时候,  物品只能 取 1 次.(01 背包)

代码详解:


for(int i = 0;i < goods.size();++i)
{for(int j = v;j >= goods[i].v;--j){dp[j] = max(dp[j],dp[j - goods.v] + goods.w);}
}/*逆向 的时候,  j == 背包容量(v)   时, 只能取当前的一个 物品 i  随后随着 --j   后面  dp[j]  紧随其后  只取一个物品 i       所以达到了,只取 一次 的效果
*/   

 背包 正向 遍历的时候,  物品可以取多次.(完全 背包)

代码详解:


for(int i = 0;i < goods.size();++i)
{for(int j = goods[i].v;j <= v;++j){dp[j] = max(dp[j],dp[j - goods.v] + goods.w);}
}/*正向 的时候,  j == 物品容量(goods.v)   时, 取当前的一个 物品 i  随后随着 ++j   后面  dp[j]  紧随其后 取一个物品 i       直到达到了 dp[v] ,使得 物品 i 取了多次
*/   

所以 完全背包问题 和 01 背包问题区别在于 遍历背包的顺序。

同样的道理,我们结合dp递推的公式 + 背包遍历顺序,就可以解出这道完全背包问题方案数的问题了。

在这里再扩展一下问题,遍历顺序中,先遍历背包还是先遍历物品?

我们再看一下这两种遍历方法的效果:

①先遍历物品再遍历背包


for(int i = 0;i < goods.size();++i)    // 遍历物品
{for(int j = goods[i].v;j <= v;++j)    // 遍历背包{dp[j] = max(dp[j],dp[j - goods.v] + goods.w);}
}/*假设 物品 等于 下标那么背包会得到的集合是:{1} {1,2} , {2}{1,2,3} , {2,3} , {3}....获取的集合中不会出现 {2,1}... 等集合说明 先遍历物品再遍历背包是一个  组合 数*/   

②先遍历背包再遍历物品

for(int j = goods[i].v;j <= v;++j)    // 遍历背包
{for(int i = 0;i < goods.size();++i)    // 遍历物品{dp[j] = max(dp[j],dp[j - goods.v] + goods.w);}
}/*假设 物品 等于 下标那么背包会得到的集合是:{1} {1,2} , {2,1} ,{2}....获取的集合中会出现 {2,1}... 等集合说明 先遍历物品再遍历背包是一个  排列 数*/   

所以 背包问题 遍历顺序中 :

先遍历物品再遍历背包: 组合 数。

先遍历背包再遍历物品: 排列 数。

综上所述。

代码详解如下:

inline int change(int& amount, vector<int>& coins) 
{vector<int>dp(amount + 1,0);dp[0] = 1;    // dp 初始化  凑成 0 有 1种方法 就是 +0// 组合数遍历for(int &i:coins)    // 遍历物品{for(int j = i;j <= amount;++j)    // 遍历背包{dp[j] += dp[j - i];    // dp 递推公式}}return dp[amount];    // 返回结果
}

最后提交:

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

相关文章:

  • 厦门建网站网址网站备案审核制度
  • 朝阳网站seo杭州网站建设书生商友
  • 做网站平台国外可以做自媒体的网站
  • 东莞网站建设公司制作网站个人网站可以做淘宝客网站吗
  • 网站建设需要的流程im聊天软件开发
  • 重庆专业的网站建设公司html5网络公司网站模板
  • 南京网站制作设计公司安装discuz x 3.1 网站虚拟主机的要求
  • 网站建设报价单表格天津企业展厅设计公司
  • 网站的做网站公司出口网站建设方案
  • 手机老是下载一些做任务的网站建设020网站需要多少钱
  • 天津 交友 网站建设做业务的网站
  • linuxvps建站教程青岛企业名录大全
  • 商务网站创建经费预算网站建设的运营计划
  • 用php源码如何建设网站浏览器游戏网址
  • 电商网站建设论文参考文献wordpress 主页 插件
  • 怎么快速推广网站如何设置中国建设银行网站
  • 专业做网文的网站有哪些苏州网站建设哪家快
  • 上海专业网站建设费用wordpress在线安装
  • 电商网站建设懂你所需杭州建设网考试信息网
  • 监理企业建设部网站年报工程项目信息
  • 六安建设机械网站优秀集团网站
  • qt 可以做网站吗最火的传奇手游网站
  • 张槎网站设计杭州建设工程交易网
  • 手机触屏版网站管理系统仿v电影wordpress
  • wordpress检查全站链接wordpress两步验证码
  • 网站设计规划范文建个大型网站要多少钱
  • 肇东网站建设云聚达网站建设考评表
  • 十三五关于网站建设免费下载微信2023
  • 网站备案初审过了建筑工程信息网站
  • 做本地房产网站wordpress小程序扫码登录