下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、精選文檔試驗(yàn)五 箱子裝載問題一、試驗(yàn)?zāi)康?、 理解和復(fù)習(xí)所學(xué)各種算法的概念;2、 把握和復(fù)習(xí)所學(xué)各種算法的基本要素;3、 把握各種算法的優(yōu)點(diǎn)和區(qū)分;4、 通過應(yīng)用范例把握選擇最佳算法的設(shè)計(jì)技巧與策略;二、試驗(yàn)內(nèi)容及要求1、使用貪心算法、回溯法、分支限界法解決箱子裝載問題。(任選兩種)2、通過上機(jī)試驗(yàn)進(jìn)行算法實(shí)現(xiàn)。 3、保存和打印出程序的運(yùn)行結(jié)果,并結(jié)合程序進(jìn)行分析,上交試驗(yàn)報(bào)告。三、試驗(yàn)原理回溯法原理:從開頭結(jié)點(diǎn)動(dòng)身,以深度優(yōu)先方式搜尋整個(gè)解空間。這個(gè)節(jié)點(diǎn)成為活結(jié)點(diǎn),同時(shí)也成為當(dāng)前的擴(kuò)展節(jié)點(diǎn)。在當(dāng)前的擴(kuò)展節(jié)點(diǎn)處,搜尋向縱深方向全都一個(gè)新節(jié)點(diǎn)。貪心算法原理:貪心算法通過一系列的選擇來得到問題的解
2、。他所做的每一個(gè)選擇都是當(dāng)前狀態(tài)下局部最好選擇,即貪心選擇。四、程序代碼(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+)/為每個(gè)物品編序號(hào) 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("請(qǐng)輸入物品個(gè)數(shù):");scanf("%d", &n);printf("請(qǐng)輸入最大容量:");scanf("%d", &c);int x200;/存儲(chǔ)物品編號(hào) int w200;/存儲(chǔ)每個(gè)物品重量for (int i = 0; i<n; i+)printf("請(qǐng)輸入第%d個(gè)物品重量:", 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("裝入物品編號(hào)為:");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 ;/存放最優(yōu)解int wnum;/集裝箱重量int xnum;/解int bestw = 0
6、;/最優(yōu)裝船重量int cw = 0;/當(dāng)前已裝船重量int n;/集裝箱個(gè)數(shù)int c1;/第一船的重量int c2;/其次船的重量/限界函數(shù) int bound(int t)/ 選擇當(dāng)前節(jié)點(diǎn)又分支的剩余集裝箱重之和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)/到底葉子節(jié)點(diǎn),求得一個(gè)可行解if (cw>bestw)/當(dāng)前解比以前解更優(yōu) bestw = cw;for (i = 1; i <
7、= n; i+)bestxi = xi;return;elseif (cw + wt<c1)/左分支滿足約束條件xt = 1;cw = cw + wt;loadingRec(t + 1);/前進(jìn)連續(xù)搜尋下一節(jié)點(diǎn)/回溯;回復(fù)cw與xt的值cw = cw - wt;xt = 0;if (bound(t)>bestw)/右分支滿足限界條件loadingRec(t + 1);int main()n = 4;/集裝箱個(gè)數(shù)w1 = 4, w2 = 5, w3 = 3, w4 = 2;/集裝箱重量c1 = 8;/第一個(gè)船重量c2 = 7;/其次個(gè)船重量cw = 0;bestw = 0;loadi
8、ngRec(1);/從第一個(gè)集裝箱開頭裝箱printf("第一船的最優(yōu)裝載量為:%dn", bestw);printf("第一船的最優(yōu)解為");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("無法將剩余集裝箱轉(zhuǎn)入其次船,問題無解");elseprintf("可以將剩余集裝箱裝入其次船,問題
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度木材行業(yè)市場(chǎng)調(diào)研與營銷策劃合同4篇
- 2025年企業(yè)投資貸款合同
- 2025年家具家電購買合同
- 2025年分期付款汽車銷售合同
- 2025年天然氣輸氣管道合作協(xié)議
- 2025版住宅小區(qū)水電暖消防系統(tǒng)改造與節(jié)能評(píng)估服務(wù)合同3篇
- 2025年健身健康檢測(cè)合同
- 2025年二手房合同樣本
- 二零二五至二零二五年度通信設(shè)備采購合同2篇
- 2025版屋面防水勞務(wù)分包合同(含防水檢測(cè)服務(wù))3篇
- 獅子王影視鑒賞
- 一年級(jí)數(shù)學(xué)加減法口算題每日一練(25套打印版)
- 2024年甘肅省武威市、嘉峪關(guān)市、臨夏州中考英語真題
- DL-T573-2021電力變壓器檢修導(dǎo)則
- 繪本《圖書館獅子》原文
- 安全使用公共WiFi網(wǎng)絡(luò)的方法
- 2023年管理學(xué)原理考試題庫附答案
- 【可行性報(bào)告】2023年電動(dòng)自行車相關(guān)項(xiàng)目可行性研究報(bào)告
- 歐洲食品與飲料行業(yè)數(shù)據(jù)與趨勢(shì)
- 放療科室規(guī)章制度(二篇)
- 中高職貫通培養(yǎng)三二分段(中職階段)新能源汽車檢測(cè)與維修專業(yè)課程體系
評(píng)論
0/150
提交評(píng)論