




下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选文档试验五 箱子装载问题一、试验目的1、 理解和复习所学各种算法的概念;2、 把握和复习所学各种算法的基本要素;3、 把握各种算法的优点和区分;4、 通过应用范例把握选择最佳算法的设计技巧与策略;二、试验内容及要求1、使用贪心算法、回溯法、分支限界法解决箱子装载问题。(任选两种)2、通过上机试验进行算法实现。 3、保存和打印出程序的运行结果,并结合程序进行分析,上交试验报告。三、试验原理回溯法原理:从开头结点动身,以深度优先方式搜寻整个解空间。这个节点成为活结点,同时也成为当前的扩展节点。在当前的扩展节点处,搜寻向纵深方向全都一个新节点。贪心算法原理:贪心算法通过一系列的选择来得到问题的解
2、。他所做的每一个选择都是当前状态下局部最好选择,即贪心选择。四、程序代码(1)贪心算法#include<stdio.h>#include<stdlib.h>void swap(int &x, int &y)/交换 int t;t = x;x = y;y = t;void sort(int w, int t, int n)/排序,有小到大 for (int m = 0; m<n; m+)/为每个物品编序号 tm = m;int i, j;int lastExchangeIndex;i = n - 1;while (i>0)lastExchang
3、eIndex = 0;for (j = 0; j<i; j+)if (wj + 1<wj)swap(wj + 1, wj);/物品的重量交换lastExchangeIndex = j;swap(tj, tj + 1);i = lastExchangeIndex;void loading(int x, int w, int c, int n, int *t)/最有装载sort(w, t, n);for (int i = 0; i<n; i+)xi = 0;for (int j = 0; j<n&&wtj <= c; j+)xtj = 1;c -= w
4、tj;/装入 int mian()int n, c;printf("请输入物品个数:");scanf("%d", &n);printf("请输入最大容量:");scanf("%d", &c);int x200;/存储物品编号 int w200;/存储每个物品重量for (int i = 0; i<n; i+)printf("请输入第%d个物品重量:", i);scanf("%d", &wi);int *t = new intn;/物品是否装入fo
5、r (int j = 0; j<n; j+)xj = 0;/初始化物品均未装入loading(x, w, c, n, t);printf("装入物品编号为:");for (int k = 0; k<n; k+)if (xk = 1)printf("%d ", tk);return 0;(2)回溯法#include<stdio.h>#include<stdlib.h>#define num 100int bestxnum = 0 ;/存放最优解int wnum;/集装箱重量int xnum;/解int bestw = 0
6、;/最优装船重量int cw = 0;/当前已装船重量int n;/集装箱个数int c1;/第一船的重量int c2;/其次船的重量/限界函数 int bound(int t)/ 选择当前节点又分支的剩余集装箱重之和int rw = 0;for (int i = t + 1; t<n; t+)rw = rw + wi;return (rw + cw);/上界 /递归求解void loadingRec(int t)int i;if (t>n)/到底叶子节点,求得一个可行解if (cw>bestw)/当前解比以前解更优 bestw = cw;for (i = 1; i <
7、= n; i+)bestxi = xi;return;elseif (cw + wt<c1)/左分支满足约束条件xt = 1;cw = cw + wt;loadingRec(t + 1);/前进连续搜寻下一节点/回溯;回复cw与xt的值cw = cw - wt;xt = 0;if (bound(t)>bestw)/右分支满足限界条件loadingRec(t + 1);int main()n = 4;/集装箱个数w1 = 4, w2 = 5, w3 = 3, w4 = 2;/集装箱重量c1 = 8;/第一个船重量c2 = 7;/其次个船重量cw = 0;bestw = 0;loadi
8、ngRec(1);/从第一个集装箱开头装箱printf("第一船的最优装载量为:%dn", bestw);printf("第一船的最优解为");for (int i = 1; i <= n; i+)printf("%d ", bestxi);/求剩余集装箱的重量int cw2 = 0;for (int i = 0; i <= n; i+)if (bestxi = 0)cw2 += wi;if (cw2>c2)printf("无法将剩余集装箱转入其次船,问题无解");elseprintf("可以将剩余集装箱装入其次船,问题
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 民宿经营合同范本及注意事项解析
- 建筑工程项目绿色施工管理可行性报告
- 工业机器人安全操作规程及培训教材
- 病历书写基本规范考核试题及答案
- 仓库安全消防培训试题及答案
- 中心静脉导管维护班结业理论考核试题附答案
- 2025年全国施工员土建施工基础知识考试真题及解析
- 销售团队客户关系管理技巧分享
- 大型化工装置基础地基施工设计汇编
- 2025年消除三病母婴传播培训测试题及答案
- 项目经理(总监)解锁申请表
- 物业管理存在的问题与对策
- 前列腺等离子电切术护理查房
- 儿童神经心理行为发育
- GB/T 4074.8-2009绕组线试验方法第8部分:测定漆包绕组线温度指数的试验方法快速法
- GB/T 19812.3-2017塑料节水灌溉器材第3部分:内镶式滴灌管及滴灌带
- GB/T 1682-1994硫化橡胶低温脆性的测定单试样法
- 企业消防安全基础知识培训讲义课件
- 自驾游免责协议书
- 商务英语翻译实务完整版教学ppt课件全套教程
- 第五章-中药指纹图谱课件
评论
0/150
提交评论