下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验题目:背包问题实验目的:掌握动态规划、贪心算法的原理,并能够按其原理编程实现解决背包问题,以加深对上述方法的理解。实验内容:一个旅行者准备随身携带一个背包. 可以放入背包的物品有n 种, 每种物品的重量和价值分别为 wj , vj . 如果背包的最大重量限制是 b, 怎样选择放入背包的物品以使得背包的价值最大?目标函数:约束条件:线性规划问题 由线性条件约束的线性函数取最大或最小的问题整数规划问题 线性规划问题的变量 xj 都是非负整数Fk(y):装前 k 种物品, 总重不超过 y, 背包的最大价值i(k,y):装前 k 种物品, 总重不超过 y, 背包达最大价值时装入物品的最大标号递推方
2、程、边界条件、标记函数实例计算:v1 = 1, v2 = 3, v3 = 5, v4 = 9, w1 = 2, w2 = 3, w3 = 4, w4 = 7, b = 10 Fk(y) 的计算表如下:K/y1234567891010112233445201334667993013556810101140135569101012实验步骤: 1、分析题目; 2、打开NetBeans软件,新建一个名叫 Knapsackdxj的项目,并对其进行保存; 3在新建的项目下对我们所分析的题目进行编写; 4、调试所编写的程序; 5、运行文件,并对其进行测试,看是否正确。实验结果:实验小结:在做本次实验之前,自
3、己对动态规划、贪心算法的原理不是非常的理解,花了很多时间看了课本上的相关内容。当你懂得算法的基本原理后,再参考老师所提供的代码进行完善补充,必须结合算法的实际情况对代码中的相关变量进行修改,这样才能充分利用课本所提供的代码完成本次实验。通过本次试验,自己基本上掌握上述算法解背包问题的原理,达到实验的目的。实验代码:Knapsack.Javapackage chap4;import java.util.Scanner;/* * * author Jinyu */public class Knapsack /*常量定义* static final int MAX_NUM = 20; static
4、final int MAX_WEIGHT = 100;/*自定义数据结构* /*题目描述中的变量* private final int weight = new intMAX_NUM; private final int value = new intMAX_NUM; private final int x = new intMAX_NUM; private final int m = new intMAX_NUMMAX_NUM; private final int s = new intMAX_NUMMAX_NUM; private int n; private int w; int h;
5、int l;/*算法实现* public void solve() int k = 1; int a = 1; for (int i = 1; i = n; i+) for (int j = 1; j = w; j+) a = 1; k = 1; if (weighti = j) h = weighti; l = valuei; while (h mi - 1j - h + l | mij (mi - 1j - h + l) /判断是否应该装入 if (k = 1) /第一次的时候才执行不放入的操作,k不等于1的时候保持上一次操作的结果不进行改变 mij = mi - 1j;/不装入 sij
6、= 0; a = 0; else mij = mi - 1j - h + l;/应该装入 sij = k;/存放装入次数,用于求最优解 k+;/装入后k加1 h = weighti * k; l = valuei * k;/ System.out.println(h + e);/测试 / System.out.println(h + c);/ System.out.println(i + + j + + mij);/测试 else if (mij mi - 1j) /无法装入 mij = mi - 1j; if (k = 1) sij = 0; / System.out.println(i +
7、 + j + + mij);/测试 System.out.println(可装入物品的最大价值为: + mnw);/ for (int i = 1; i = n; i+) /测试/ for (int j = 1; j 1; i-) /由最后一个数据向上推算 y = y - xi * weighti; xi - 1 = si - 1y;/将每个物品的装入信息存放起来 for (int i = 1; i = n; i+) System.out.println(第 + i + 个物品放入 + xi + 样); public void input() Scanner scanner = new Sca
8、nner(System.in); System.out.println(请输入背包能够承受的总重量:); w = scanner.nextInt(); System.out.println(请输入可以装入背包的物品的种类:); n = scanner.nextInt(); System.out.println(请输入 + n + 种物品中每一种物品的重量和价值:); for (int i = 1; i = n; i+) weighti = scanner.nextInt(); valuei = scanner.nextInt(); Test.javapackage chap4;/* * * author Jinyu */public class Test /* * param args the command line arguments */ public static void main(String args) /
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 46794-2025化工园区气体防护站建设运行指南
- 2025年兴业银行珠海分行社会招聘备考题库及参考答案详解一套
- 2026年建筑材料标准化合同
- 2026年建筑质量保证金合同
- 2025年达州银行股份有限公司社会招聘备考题库带答案详解
- 2026年药品含量测定方法学验证合同
- 2025年广西工艺美术研究院有限公司所属企业广西绢麻纺织科学研究所有限公司招聘备考题库及参考答案详解
- 急性乳腺炎沟通记录
- 2025年安全生产监管人员考试试题及答案(完整版)
- 2025年济南市检察机关公开招聘聘用制书记员25人备考题库及参考答案详解1套
- 墙壁维护施工方案(3篇)
- 人工智能安全风险测评白皮书(2025年)
- 2025下半年贵州遵义市第一人民医院招聘事业单位65人笔试备考重点试题及答案解析
- 围麻醉期应激反应的调控策略
- 2025年外贸实习合同协议
- 集成电路封装测试厂建设项目可行性研究报告
- 医院服务礼仪培训
- 亚朵酒店管理分析
- 弘历指标源码6个(仅提供源码)
- 新产品开发项目进度计划表
- 设计公司生产管理办法
评论
0/150
提交评论