版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、算法設計課程報告課題名稱: 算法設計課題負責人名(學號):-同組成員名單(角色):-指導教師:二評閱成績:評閱意見:提交報告時間:2014年6月17日專業(yè)整理最小重量機器設計問題計算機科學與技術專業(yè)學生-指導老師 -題目描述設某一機器由 n個部件組成,每一種部件都可以從 m個不同的供應商處購得。高 wij是從供應商 j處購得的部件 i的重量,cij是相應的價格。試設計一個算法,給出總價格不超過c的最小重量機器設計。編程任務:對于給定的機器部件重量和機器部件價格,編程計算總價格不超過 d的最小重量機器設計。數據輸入:由文件 input.txt給出輸入數據。第一行有3個正整數 n ,m和d。接正業(yè)
2、的 2n行,每行 n個數。前 n行是 c,后n行是 w。結果輸出:將計算出的最小重量,以及每個部件的供應商輸出到文件output.txt 。輸入文件示例輸出文件示例input.txtoutput.txt3 3 441 2 31 3 13 2 12 2 21 2 33 2 12 2 2算法分析采用回溯算法和分支定界法分別實現,對于回溯法,采用深度優(yōu) 先搜索對子集樹進行剪枝,剪枝條件是當前的總費用不超過總費用; 對于分支定界法,采用按照層次遍歷對子集樹進行剪枝,并將每層的 結點按照重量由小到大進行排序,將相應下標保存在二維數組s中,以便構造最優(yōu)解。兩種算法是時間復雜度都是 O(m"),空
3、間復雜度均為 O(nm), 但由于分支定界法在已經排好序的序列中查找,因此查找到的第一個 解即為最優(yōu)解,理論上來說,時間效率會比回溯法高。程序實現回溯法代碼#include <iostream>#include <stdlib.h>#include <fstream>#include <vector>#include <stdio.h>#include <string.h> using namespace std;#define INF 999999999#define MAXSIZE 100+1int cur_solut
4、ionMAXSIZE;int solutionMAXSIZE;int wMAXSIZEMAXSIZE; /weightint cMAXSIZEMAXSIZE; /costint minWeight;int cur_minWeight;void Backtrack(int t,int n,int m,int d)if(t>n)if(cur_minWeight < minWeight)/保存最優(yōu)解和最優(yōu)值minWeight = cur_minWeight;for(int r=1;r<=n;+r)solutionr = cur_solutionr;elsefor(int i=1;i
5、<=m;+i)d -= cti;cur_solutiont = i;cur_minWeight += wti;if(d>=0)Backtrack(t+1,n,m,d);cur_minWeight -= wti;/if(Constraint(t) && Bound(t)Backtrack(t+1,n,m,d);d += cti;return;int main()int n,m,d;cout<<"Please input the input file path:"<<endl;char strPath63;while(scan
6、f("%s",strPath)=1)ifstream fin(strPath);cout<<"Please input the output file path:"<<endl;cin>>strPath;ofstream fout(strPath);if(fin.good() && fout.good()minWeight = INF;cur_minWeight = 0;fin>>n>>m>>d;int j,k;for(j=1;j<=n;+j)for(k=1;k
7、<=m;+k) fin>>cjk;for(j=1;j<=n;+j)for(k=1;k<=m;+k) fin>>wjk;Backtrack(1,n,m,d);fout<<minWeight<<endl;for(int r=1;r<=n;+r)fout<<solutionr<<""fout<<endl;fout.close();fin.close();elsecout<<"Open file error!"<<endl;)cou
8、t<<endl<<endl<<"Please input the input file path:"<<endl;)return 0;)分支定界法代碼#include <stdio.h>#include <stdlib.h>#include <list>#include <iostream>using namespace std;#define MAX_NODE 256typedef struct _nodeint weight,price;int level,th;struct
9、 _node *prev;node;void qs(int *a,int *s,int b,int e)快速排序int t,c=asb;int l=b,r=e;while(l<r)while(l<r&&asr>=c)-r;t=sr;sr=sl;sl=t;while(l<r&&asl<c)+l;t=sr;sr=sl;sl=t;if(b<l)qs(a,s,b,l-1);if(l<e)qs(a,s,l+1,e);)int main()(int *w=0,*p=0,n,m,c,i,j;int *minprice;int leve
10、l,price,weight;list<node*> que;list<node*>:iterator it;node *pnode;/*讀取文件*/FILE *pf;if(pf=fopen("input.txt","r")!=0)(fscanf(pf,"%d%d%d",&n,&m,&c);重量價格w=(int *)malloc(n*m*sizeof(int);/ p=(int *)malloc(n*m*sizeof(int);/ for(i=0;i<n;+i)for(j=0;j&
11、lt;m;+j)fscanf(pf,"%d",w+i*m+j);for(i=0;i<n;+i)for(j=0;j<m;+j)fscanf(pf,"%d",p+i*m+j); fclose(pf);)else(printf("no input file!n");getchar();)/*準備數據 */int snm;用來為每一種零件的質量排序,for(i=0;i<n;+i)for(j=0;j<m;+j)sij=j;minprice=(int*)malloc(n+1)*sizeof(int);/用來記錄買了i 個零
12、件后,買完剩下的零件至少還要多少錢minpricen=0;/買了 n個零件之后,不需要再買了for(i=0;i<n;+i)minpricei=pi*m;for(j=1;j<m;+j) 找出買第i個零件的最低價格 minpricei=minpricei<pi*m+j?minpricei:pi*m+j;)for(i=n-2;i>=0;-i)計算買剩下的零件至少要多少錢minpricei=minpricei+1+minpricei;)for(i=0;i<n;+i)每種零件按重量排序,排序下標記錄的s中,排序后wi*m+sij , i相同時,對于變量j是遞增的qs(w+i
13、*m,si,0,m-1);/*開始計算 */for(i=0;i<m;+i)初始數據把第一種零件的所有情況放入活結點隊列pnode=new node;pnode->weight=ws0i;pnode->price=ps0i;if(pnode->price+minprice2<=c) (pnode->th=i;pnode->level=1;pnode->prev =0;que.push_back(pnode); else delete pnode; while(!que.empty()計算,直到得出結果或者隊列為空(level =que.front(
14、)->level;price =que.front()->price;weight=que.front()->weight;if(level<n)for(i=0;i<m;+i)如果隊首不為葉子結點,擴展隊首結點(pnode=new node;pnode->weight=weight+wlevel*m+sleveli;pnode->price=price+plevel*m+sleveli;if(pnode->price+minpricelevel+1<=c) 剪枝,如果當前結點剩下的錢不夠買全所有零件,則剪掉(pnode->th=sle
15、veli;pnode->level=level+1;pnode->prev =que.front();for(it=que.begin();it!=que.end();+it)按重量遞增構造優(yōu)先隊列if(pnode->weight<(*it)->weight)break;que.insert(it,pnode);退出循環(huán)if(level=n-1)break;如果已經找到答案,)else delete pnode;)que.pop_front();if(i<m)break;如果已經找到答案,退出循環(huán))/*輸出答案 */if(pnode->level!=n
16、)printf("can not find answer!");getchar();exit(0);)pf=fopen("output.txt","w");if(pf)fprintf(pf,"%dn",pnode->weight);int count=n,ansn;while(pnode)ans-count=pnode->th;pnode=pnode->prev;)for(i=0;i<n;+i)fprintf(pf,"%d ",ansi);fputc('n',pf);fclose(pf);if(minprice)free(minprice);if(w)free(w);if(p)free(p);return 0;運行結果回溯法運行結果如下,分支定界法結果與下列一致,讀者可以自行運行比對' C:Use rsAd rninistrato rD eski c»phorrie算法設計作U? wo rkDellease input the input flie path:XUsersXAdministE'atorXDesktDpXl _txt lease input the output file path=:
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度中醫(yī)養(yǎng)生產品海外市場推廣合同4篇
- 2025年度商業(yè)綜合體承包轉讓合同范本4篇
- 2025年度養(yǎng)老機構場地租賃與養(yǎng)老服務分成管理合同3篇
- 2025年cfg樁基施工項目環(huán)境保護與生態(tài)修復合同3篇
- 2025年度智能家電維修個人勞務協(xié)議書4篇
- 2025年中國酚氨咖敏顆粒行業(yè)發(fā)展?jié)摿Ψ治黾巴顿Y戰(zhàn)略咨詢報告
- 2025年度汽車租賃與二手車交易服務合同3篇
- 2025年溫州家和物業(yè)管理有限公司招聘筆試參考題庫含答案解析
- 2025年溫州個人房屋買賣合同(含交易資金監(jiān)管)3篇
- 二零二五版離婚協(xié)議書模板:離婚后子女撫養(yǎng)及財產分割專案協(xié)議2篇
- 氧氣霧化吸入法
- 6月大學英語四級真題(CET4)及答案解析
- 氣排球競賽規(guī)則
- 電梯維修保養(yǎng)報價書模板
- 危險化學品目錄2023
- FZ/T 81024-2022機織披風
- GB/T 33141-2016鎂鋰合金鑄錠
- 2023譯林版新教材高中英語必修二全冊重點短語歸納小結
- JJF 1069-2012 法定計量檢定機構考核規(guī)范(培訓講稿)
- 綜合管廊工程施工技術概述課件
- 公積金提取單身聲明
評論
0/150
提交評論