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

做旅游的网站的需求万州网站制作公司

做旅游的网站的需求,万州网站制作公司,静态化网站和app的区别,企业网站静态模板下载目录 474. 一和零 518. 零钱兑换 II 377. 组合总和 Ⅳ 322. 零钱兑换 总结&#xff1a; 474. 一和零 这道题和前面的思路一样&#xff0c;就是需要将背包扩展到二维。 class Solution { public:int findMaxForm(vector<string>& strs, int m, int n) {vector&l…

 

目录

474. 一和零

518. 零钱兑换 II 

377. 组合总和 Ⅳ 

 322. 零钱兑换

 总结:


474. 一和零

 

这道题和前面的思路一样,就是需要将背包扩展到二维。

class Solution {
public:int findMaxForm(vector<string>& strs, int m, int n) {vector<vector<int>> dp(m+1,vector<int>(n+1,0));for(auto s:strs){int oneNum=0,zeroNum=0;for(auto c:s){if(c=='0')  zeroNum++;else if(c=='1') oneNum++;}for(int i=m;i>=zeroNum;i--){for(int j=n;j>=oneNum;j--){dp[i][j]=max(dp[i][j],dp[i-zeroNum][j-oneNum]+1);}}}return dp[m][n];}
};

518. 零钱兑换 II 

 

每个硬币可以无限制取,完全背包问题。先确定dp[i]表示的含义,i表示背包容量,dp[j]表示该容量有多少种方法。再确定递推公式,dp[j]+=dp[j-coins[i]];。最后确定遍历顺序,因为每个硬币都可以无限制取,所以j的遍历顺序应该为正序。

注意:在01背包中为了防止元素重复取,采用倒序

class Solution {
public:int change(int amount, vector<int>& coins) {vector<int> dp(amount+1,0);dp[0]=1;for(int i=0;i<coins.size();i++){for(int j=coins[i];j<=amount;j++){dp[j]+=dp[j-coins[i]];}}return dp[amount];}
};


377. 组合总和 Ⅳ 

 

 这题和上题的区别在于这题是排列,上题是组合。组合问题先遍历物品后遍历背包容积,排列问题先遍历背包容积后遍历物品。进入循环里面思考一下就明白了怎么回事了。

class Solution {
public:int combinationSum4(vector<int>& nums, int target) {vector<int> dp(target+1,0);dp[0]=1;//遍历背包容积for(int j=0;j<=target;j++){//遍历物品for(int i=0;i<nums.size();i++){if(j<nums[i] || dp[j]>INT_MAX-dp[j-nums[i]])   continue;dp[j]+=dp[j-nums[i]];}}return dp[target];}
};

 322. 零钱兑换

 

这题的不同之处在于求最小硬币个数,初始化的时候注意初始化为最大值。

class Solution {
public:int coinChange(vector<int>& coins, int amount) {vector<int> dp(amount+1,INT_MAX);dp[0]=0;for(int i=0;i<coins.size();i++){for(int j=coins[i];j<=amount;j++){//如果dp[j-coins[i]]==INT_MAX,将超出int的范围if(dp[j-coins[i]]!=INT_MAX)dp[j]=min(dp[j],dp[j-coins[i]]+1);}}if(dp[amount]==INT_MAX) return -1;return dp[amount];}
};

 总结:

01背包问题和完全背包问题的主要区别是元素是否可以无限制取。

在解决问题的方式上,如果是求组合就先遍历物品再遍历背包容积,如果是求排列就先遍历背包容积再遍历物品。

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

相关文章:

  • 长沙哪里做网站好wordpress批量删除
  • 注册网站授权书怎么写网页升级紧急通知页面升级
  • html做的宠物网站西部网站助手
  • 怎么建设一个社交网站流量点击推广平台
  • 网站开发上线流程网站建设实习任务完成情况
  • 郑州哪家建设网站做优化需要发多少个网站
  • 绵阳银行网站建设广东佛山网络科技有限公司
  • 台州网站优化方案做软件的步骤
  • 素材网站个人做的wordpress iis 中文
  • 嘉兴网站建设有前途吗上海制作企业网站
  • 长沙网站拓谋网络网络广告推广计划方案
  • 定西建设厅网站做ppt模板下载网站
  • 深圳做装修网站费用多少百度推广最简单方法
  • 怎么开发手机网站seo诊断表
  • 网站模板如何修改域名调用wordpress数据库连接
  • 域客式单页网站能申请域名吗百度搜索引擎首页
  • 泸州本地网站建设网站推广包括
  • 网站开发的实例wordpress转到手机端
  • wordpress最强的教育网站平面设计基础教程
  • 企业网站建设一般要素包括沈阳网站建设 南塔
  • 长沙装修网站排名教育机构还能补课吗
  • 网站建设怎么找客户办公用纸网站建设
  • 网站优化网络推广seo莱芜新闻最新事件
  • 开发网站的费用属于什么费用打开网上免费网站吗
  • 做网站和域名设计制作小车教学视频
  • 电商网站建设免费wordpress上传到主机
  • 做百度网站费用在线logo
  • 做测算的网站昆明网络推广哪里有
  • 网站建设公司 资讯网站建设销售总结
  • 做微网站平台阳东区网络问政平台