




下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、實驗五 箱子裝載問題一、實驗目的1、 理解和復習所學各種算法的概念;2、 掌握和復習所學各種算法的基本要素;3、 掌握各種算法的優(yōu)點和區(qū)別;4、 通過應用范例掌握選擇最佳算法的設計技巧與策略;二、實驗內容及要求1、使用貪心算法、回溯法、分支限界法解決箱子裝載問題。(任選兩種)2、通過上機實驗進行算法實現(xiàn)。 3、保存和打印出程序的運行結果,并結合程序進行分析,上交實驗報告。三、實驗原理回溯法原理:從開始結點出發(fā),以深度優(yōu)先方式搜索整個解空間。這個節(jié)點成為活結點,同時也成為當前的擴展節(jié)點。在當前的擴展節(jié)點處,搜索向縱深方向一致一個新節(jié)點。貪心算法原理:貪心算法通過一系列的選擇來得到問題的解。他所做
2、的每一個選擇都是當前狀態(tài)下局部最好選擇,即貪心選擇。四、程序代碼(1)貪心算法#include#includevoid 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; m0)lastexchangeindex = 0;for (j = 0; ji; j+)if (wj + 1wj)swap(wj + 1, wj);/物品的重量交換lastexchangeindex = j;swap(tj, tj + 1);i = lastexchange
3、index;void loading(int x, int w, int c, int n, int *t)/最有裝載sort(w, t, n);for (int i = 0; in; i+)xi = 0;for (int j = 0; jn&wtj = c; j+)xtj = 1;c -= wtj;/裝入 int mian()int n, c;printf(請輸入物品個數(shù):);scanf(%d, &n);printf(請輸入最大容量:);scanf(%d, &c);int x200;/存儲物品編號 int w200;/存儲每個物品重量for (int i = 0; in; i+)printf
4、(請輸入第%d個物品重量:, i);scanf(%d, &wi);int *t = new intn;/物品是否裝入for (int j = 0; jn; j+)xj = 0;/初始化物品均未裝入loading(x, w, c, n, t);printf(裝入物品編號為:);for (int k = 0; kn; k+)if (xk = 1)printf(%d , tk);return 0;(2)回溯法#include#include#define num 100int bestxnum = 0 ;/存放最優(yōu)解int wnum;/集裝箱重量int xnum;/解int bestw = 0;/最
5、優(yōu)裝船重量int cw = 0;/當前已裝船重量int n;/集裝箱個數(shù)int c1;/第一船的重量int c2;/第二船的重量/限界函數(shù) int bound(int t)/ 選擇當前節(jié)點又分支的剩余集裝箱重之和int rw = 0;for (int i = t + 1; tn)/到底葉子節(jié)點,求得一個可行解if (cwbestw)/當前解比以前解更優(yōu) bestw = cw;for (i = 1; i = n; i+)bestxi = xi;return;elseif (cw + wtbestw)/右分支滿足限界條件loadingrec(t + 1);int main()n = 4;/集裝箱個
6、數(shù)w1 = 4, w2 = 5, w3 = 3, w4 = 2;/集裝箱重量c1 = 8;/第一個船重量c2 = 7;/第二個船重量cw = 0;bestw = 0;loadingrec(1);/從第一個集裝箱開始裝箱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 c2)printf(無法將剩余集裝箱轉入第二船,問題無解);elseprintf(可以將剩余集裝箱裝入第二船,問題有解);getchar();五、結果運行與分析(1)貪心
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 海邊防護欄施工組織計劃方案
- 城市小學校本課程開發(fā)計劃
- 以弗魯姆期望理論為鑰開啟初中生思想品德課興趣之門
- 以審美體驗為核奏響中小學音樂欣賞教學新樂章
- 保險公司總務處資料歸檔計劃
- 幼兒園后勤管理崗位職責
- 2025年“書香校園”創(chuàng)新閱讀競賽方案計劃
- 石油天然氣工程投標質量保證及售后服務計劃
- 外貿企業(yè)疫情防控措施提升
- 浙江省桐鄉(xiāng)市第一中學2025年高二下化學期末綜合測試模擬試題含解析
- 2024年中國中式養(yǎng)生水行業(yè)發(fā)展趨勢洞察報告
- (完整版)自由泳教案
- 《困境兒童風險評估規(guī)范》
- 國開2024年《機械設計基礎》形考任務1-4答案
- CJT121-2000 再生樹脂復合材料檢查井蓋
- 生物的分子進化和分子遺傳學
- 北京小型實驗室建設計劃書
- 高校大型儀器設備利用評價研究-以華南農業(yè)大學為例的中期報告
- 鋼結構橋梁的設計與建造:鋼結構橋梁的設計與施工要點與技術
- 中醫(yī)四大經典備考刷題庫匯總(800題)
- 外科護理學課程說課課件
評論
0/150
提交評論