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

湖北网站开发培训苏州网站关键词优化推广

湖北网站开发培训,苏州网站关键词优化推广,网页设计师 培训,做网站维护工资多少问题描述: 使用穷举法解决0/1背包问题。问题描述:给定n个重量为{w1, w2, … ,wn}、价值为{v1, v2, … ,vn} 的物品和一个容量为C的背包,求这些物品中的一个最有价值的子集,且要能够装到背包中。 穷举法:每件物品装还是…

问题描述:

使用穷举法解决0/1背包问题。问题描述:给定n个重量为{w1, w2, … ,wn}、价值为{v1, v2, … ,vn}

 的物品和一个容量为C的背包,求这些物品中的一个最有价值的子集,且要能够装到背包中。

穷举法:每件物品装还是不装有两种选择,使用0-表示不装,1表示装,n件物品就有2^n种,穷举2^n种,找到符合符合weight背包容量的且为价值最大的方式。

public class Main01 {//穷举法public void pack01(int weight,int[] wt,int[] val){int n = wt.length;int count= (int) Math.pow(2,n);int maxVal = 0;//枚举32种情况,并且记录符合weight重量背包的最大价值for (int i = 0; i < count; i++) {String res = String.format("%5s",Integer.toBinaryString(i)).replace(' ','0');System.out.print(res+"  ");int sumVal = 0;int sumWeight=0;for (int j = 0; j < n; j++) {//为1时表示装该物品 0表示不准装if (res.charAt(j)=='1') {sumVal += val[j];sumWeight += wt[j];}if (sumWeight<=weight){maxVal = Math.max(sumVal,maxVal);}}System.out.println("价值:"+sumVal+"重量:"+sumWeight);}//打印最大价值下对应的背包实际重量和所装物品的状态for (int i = 0; i<count; i++) {String res = String.format("%5s",Integer.toBinaryString(i)).replace(' ','0');int sumVal = 0;int sumWeight=0;for (int j = 0; j < n; j++) {if (res.charAt(j)=='1') {sumVal += val[j];sumWeight += wt[j];}}if (sumVal==maxVal&&sumWeight<=weight){System.out.println("当背包重量为"+weight+"时:最大价值:"+sumVal+"  总重量: "+sumWeight+"  方式:"+res);break;}}}public static void main(String[] args) {Main01 main01 = new Main01();int[] wt = {1, 2, 1, 12, 4};int[] val = {1, 2, 2, 4, 10};main01.pack01(15, wt, val);}
}

 输出结果:

 二维dp数组:

dp[i][w]数组含义:对于前i个物品,当前背包容量为w时,可装下的最大值是dp[i][w]。

dp[i-1][w-wt[i-1]]+val[i-1]:装物品i的价值

dp[i-1][w]:不装物品i的价值

因此dp[i][w]取装物品 i dp[i-1][w-wt[i-1]]+val[i-1]  和  不装物品i dp[i-1][w] 的最大值

public class Main01 {public static void main(String[] args) {int[] wt = {1, 2, 1, 12, 4};int[] val = {1, 2, 2, 4, 10};int res = pack01(15,wt,val);System.out.println("最大价值:"+res);}public static int pack01(int weight,int[] wt,int[] val){int n = wt.length;//dp[i][w]数组含义:对于前i个物品,当前背包容量为w时,可装下的最大值是dp[i][w]int[][] dp = new int[n+1][weight+1];for (int i = 1; i <= n; i++) {for (int w = 1; w <= weight; w++) {if (wt[i-1]>w){//不能装入背包dp[i][w] = dp[i-1][w];}else {//择优装入背包dp[i][w] = Math.max(dp[i-1][w-wt[i-1]]+val[i-1],dp[i-1][w]);}}}//打印dp表for (int i = 0; i <=n ; i++) {for (int j = 0; j <=weight ; j++) {if (j<weight){System.out.print(dp[i][j]+",");}else {System.out.print(dp[i][j]);}}System.out.println();}return dp[n][weight];}
}

输出结果:

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

相关文章:

  • 网站群 意义怎样做网页游戏网站
  • 网站建设课程改进建议无障碍环境建设 网站
  • 济宁市建设工程招投标网站江苏网站建设效果好
  • 新增网站备案时间hexo发布wordpress
  • 苏州网站建立公司仿礼物说网站模板
  • 想看别人的wordpress博客网站江西合创建设工程有限公司 网站
  • 网站做推广需要什么条件wordpress 虚拟机
  • 查看别人网站的访问量班级优化大师的功能有哪些
  • 设计网站推广方案从零学习做网站
  • 如何 攻击网站郑州发布最新消息今天
  • 网站 logfiles建设银行个人网上银行网页
  • 泰安网站建设开发公司国家商标注册官网
  • 浦项建设公司员工网站西城网站制作公司
  • 互联网公司网站做美团旅游网站多少钱
  • 石家庄市网站建设中国建设银行企业官网站
  • 一个公司可以注册几个网站wordpress page模版
  • 网站公司企业网站如何把网站上传到网上
  • 济宁市城市建设局网站数控技术是学什么
  • 南昌集团制作网站开发wordpress全自动淘宝客
  • 网站开发已有的知识储备用dede做的网站首页
  • 石家庄网站建设石家庄搭建网站代码
  • 3d做ppt模板下载网站1v1网站建设
  • 山东住房建设部官方网站品牌营销策划公司
  • 购物网站开发背景陕西建设信息网官网
  • 广州建设网站广州穗科建设管理有限公司网站
  • 天正电气网站建设建设网站平台需要什么硬件配置
  • 源码资源下载站用linux系统怎么自己建设网站
  • 网站建设重点步骤房价成交数据官网查询
  • 上海网站设计公司联系方式小程序怎么开店
  • 阿里云服务器做电影网站吗网站首页流程图