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

上海网站开发技术最好公司开鲁网站seo

上海网站开发技术最好公司,开鲁网站seo,怎么自己做APP网站,加强门户网站建设本题链接:. - 力扣(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.khdw.cn/news/19164.html

相关文章:

  • 差异基因做聚类分析网站外贸网站有哪些平台
  • 去除wordpress.orgseo服务建议
  • 怎样创建网站image百度竞价系统
  • 网站访问量过大北京百度关键词优化
  • 于都网站建设直通车关键词优化口诀
  • java web网站开发项目网络推广产品要给多少钱
  • 广州建站代运营公司有哪些seo扣费系统源码
  • 网站建设会出现的问题推广策划方案范文
  • 网站建设的安全技术搜索引擎营销的主要模式
  • 30g月流量网站百度搜索引擎入口
  • 网站开速度 流失百度关键词排名提升工具
  • 国内ui做的好的网站有哪些临沂百度seo
  • 厦门网站建设高级课程新产品推广方式有哪些
  • 有趣的网站名百度官网下载安装
  • 河南科技园网站建设个人建网站需要多少钱
  • 台州黄岩做网站优化网站的公司哪家好
  • 政府网站机房建设要求优化问题
  • 品牌建设文案宁波优化网站排名软件
  • b2b网站系统开发需要多久谷歌搜索引擎入口2021
  • 单位如何做网站宣传十大免费网站推广
  • 自己网站做第三方支付seo咨询解决方案
  • 阿根廷网站后缀什么平台可以发广告引流
  • 网站制作与免费网站建设怎样打百度人工客服热线
  • 网站里宣传视频怎么做信息流广告的特点
  • 做文件的网站北京关键词seo
  • 国外域名网站推荐郑州厉害的seo顾问公司
  • 宣讲家网站支部建设河南it渠道网
  • 大型科技网站建设品牌策划方案
  • 网络推广方案的主要步骤西安关键词排名优化
  • 云南网站制作需求杭州seo泽成