數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-地鐵建設(shè)問題_第1頁(yè)
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-地鐵建設(shè)問題_第2頁(yè)
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-地鐵建設(shè)問題_第3頁(yè)
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-地鐵建設(shè)問題_第4頁(yè)
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-地鐵建設(shè)問題_第5頁(yè)
已閱讀5頁(yè),還剩14頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、精選優(yōu)質(zhì)文檔-傾情為你奉上軟 件 學(xué) 院課程設(shè)計(jì)報(bào)告書課程名稱 數(shù)據(jù)結(jié)構(gòu) 設(shè)計(jì)題目 地鐵建設(shè)問題 專業(yè)班級(jí) 學(xué) 號(hào) 姓 名 指導(dǎo)教師 2013年 1 月專心-專注-專業(yè)目錄1 設(shè)計(jì)時(shí)間.22 設(shè)計(jì)目的.23 設(shè)計(jì)任務(wù).24 設(shè)計(jì)內(nèi)容.24.1需求分析.24.1.1程序所能達(dá)到的功能.24.1.2輸入、輸出的形式和輸入值的范圍.24.1.3測(cè)試數(shù)據(jù).34.2總體設(shè)計(jì).34.2.1抽象數(shù)據(jù)類型定義.34.2.2主程序的流程、模塊之間的調(diào)用關(guān)系.44.3詳細(xì)設(shè)計(jì).54.3.1 數(shù)據(jù)類型、函數(shù)的偽碼算法.54.3.2函數(shù)的調(diào)用關(guān)系圖.94.4測(cè)試與分析.104.4.1測(cè)試.104.4.2分析.114.

2、5 附錄.115 總結(jié)與展望.16參考文獻(xiàn).17成績(jī)?cè)u(píng)定.171 設(shè)計(jì)時(shí)間2012年1月21日2012年1月25日2 設(shè)計(jì)目的1.通過這次設(shè)計(jì),在數(shù)據(jù)結(jié)構(gòu)的邏輯結(jié)構(gòu)和存儲(chǔ)結(jié)構(gòu)、數(shù)據(jù)結(jié)構(gòu)的選擇應(yīng)用、算法的設(shè)計(jì)及其實(shí)現(xiàn)等方面加深對(duì)課程基本內(nèi)容的理解2.訓(xùn)練程序設(shè)計(jì)方法以及上機(jī)操作等基本技能,積累編程經(jīng)驗(yàn)3.培養(yǎng)用計(jì)算機(jī)解決實(shí)際問題的能力3 設(shè)計(jì)任務(wù)某城市要在各個(gè)轄區(qū)之間修建地鐵,由于地鐵建設(shè)費(fèi)用昂貴,因此需要合理安排地鐵建設(shè)線路,使市民可以沿地鐵到達(dá)各個(gè)轄區(qū),并使總費(fèi)用最小。4 設(shè)計(jì)內(nèi)容 4.1需求分析 4.1.1程序所能達(dá)到的功能 城市要在各個(gè)轄區(qū)之間修建地鐵來(lái)加快經(jīng)濟(jì)發(fā)展,但由于建設(shè)地鐵的費(fèi)用

3、昂貴,因此需要編寫程序合理安排地鐵的建設(shè)路線,使乘客可以沿地鐵到達(dá)各個(gè)轄區(qū),并使總的建設(shè)費(fèi)用最小。(1)使用結(jié)構(gòu)體數(shù)組,存儲(chǔ)轄區(qū)名稱(2)建立轄區(qū)間直接距離的無(wú)向圖,用鄰接矩陣存儲(chǔ)轄區(qū)間直接距離信息(2)根據(jù)讀入的轄區(qū)距離信息,計(jì)算出應(yīng)該建設(shè)哪些轄區(qū)的地鐵路線(3)輸出應(yīng)該建設(shè)的路線,以及所需建設(shè)的總里程信息4.1.2輸入、輸出的形式和輸入值的范圍輸出的形式和輸入值的范圍輸入數(shù)字和字母,字母為轄區(qū)名,數(shù)字為轄區(qū)間直接距離,名稱個(gè)數(shù)o, 0<線路個(gè)數(shù)<o(o-1),直接距離m,0<m<10000輸出的形式1:轄區(qū)名 轄區(qū)名 路程2:轄區(qū)名 轄區(qū)名 路程3:轄區(qū)名 轄區(qū)名

4、路程總費(fèi)用為:路程的和4.1.3測(cè)試數(shù)據(jù)正確輸入:轄區(qū)個(gè)數(shù):4名稱 a b c d 線路起止轄區(qū)及直接距離:a b 3、a c 5、a d 4、b c 2、b d 3、c d 2、0 0 0 開始轄區(qū):a 輸出為:1:a b 32:b c 23:c d 2總費(fèi)用:7錯(cuò)誤輸入:轄區(qū)個(gè)數(shù):4名稱 a b c d 線路及之間距離:as b 3輸出為:沒有as 這個(gè)轄區(qū)4.2總體設(shè)計(jì)4.2.1抽象數(shù)據(jù)類型定義1抽象數(shù)據(jù)類型圖的定義ADT Graph數(shù)據(jù)對(duì)象v:v是具有相同特性的數(shù)據(jù)元素的集合,成為頂點(diǎn)集。數(shù)據(jù)關(guān)系R: R=VR VR=<v,w>|v,wV且P(v,w),<v,w>

5、;表示從v到w的弧,謂詞P(v,w)定義了弧<v,w>的意義或信息 基本操作P: CreateGraph(&G,V,VR); 初始條件:V是圖的頂點(diǎn)集,VR是圖中弧的集合。 操作結(jié)果:按V和VR的定義構(gòu)造圖G。 ADT Graph4.2.2主程序的流程、模塊之間的調(diào)用關(guān)系主程序的流程開始輸入轄區(qū)個(gè)數(shù)和轄區(qū)名稱輸入各轄區(qū)之間路程判斷輸入是否正確NY建立無(wú)向圖,鄰接矩陣存儲(chǔ)普利姆算法計(jì)算最小生成樹輸出路線和總費(fèi)用結(jié)束模塊之間的調(diào)用關(guān)系(1)主函數(shù)main()調(diào)用int creatgraph(Graph *g)建立無(wú)向圖,用鄰接矩陣存儲(chǔ);(2)void MiniSpanTree_

6、PRIM(Graph g,char a10)調(diào)用int minimun(struct tree *a,Graph g)和int locatevex(Graph *g,char a10)生成樹,判斷轄區(qū)名稱輸入是否正確;(3)主函數(shù)main()調(diào)用void MiniSpanTree_PRIM(Graph g,char a10) 計(jì)算最小生成樹,輸出最優(yōu)線路和總里程。4.3詳細(xì)設(shè)計(jì)4.3.1 數(shù)據(jù)類型、函數(shù)的偽碼算法1結(jié)構(gòu)體類型typedef struct char VM10; int RMM; int vexnum; Graph; 2函數(shù)算法創(chuàng)建無(wú)向圖int locatevex(Graph *g

7、,char a10) int i; for(i=0;i<g->vexnum;i+) if(strcmp(a,g->Vi)=0) return i; if(i=g->vexnum) return -1; int creatgraph(Graph *g) int i=0,j,m,k,p,o,e; char a10,b10; printf("設(shè)置轄區(qū)的個(gè)數(shù): ");/城市中轄區(qū)的個(gè)數(shù) scanf("%d",&o); for(i=0;i<o;i+)/建立城市轄區(qū)名數(shù)組 printf("第%d個(gè)城市轄區(qū)名稱為: &q

8、uot;,i+1);scanf("%s",g->Vi); g->vexnum=o;for(i=0;i<g->vexnum;i+) for(j=0;j<g->vexnum;j+) g->Rij=INFINITY; printf("轄區(qū)之間的路程,以0 0 0為結(jié)束標(biāo)志n"); scanf("%s%s%d",a,b,&m); while(strcmp("0",a)!=0 | strcmp("0",b)!=0 | m!=0) k=locatevex(g

9、,a); p=locatevex(g,b);if(k=-1) printf("沒有%s這個(gè)轄區(qū)n",a); return 0; if(p=-1) printf("沒有%s這個(gè)轄區(qū)n",b); return 0;g->Rkp=g->Rpk=m;scanf("%s%s%d",a,b,&m); return 1; struct tree int weizhi; int lowcost;int minimun(struct tree *a,Graph g) int i,k,m=0; for(i=0;i<g.vexnu

10、m;i+) if(m=0 && ai.lowcost!=0) m=1; k=i;if(m=1 && ai.lowcost!=0) if(ai.lowcost<ak.lowcost) k=i; return k;普利姆算法求最小生成樹,輸出最優(yōu)線路及費(fèi)用void MiniSpanTree_PRIM(Graph g,char a10) struct tree closedgeM; int i,j,k,money=0; k=locatevex(&g,a); for(i=0;i<g.vexnum;i+) if(i!=k) closedgei.lowc

11、ost=g.Rki; closedgei.weizhi=k; closedgek.lowcost=0; for(i=1;i<g.vexnum;i+) k=minimun(closedge,g); money+=closedgek.lowcost; printf("%d:%s %s %dn",i,g.Vclosedgek.weizhi,g.Vk,closedgek.lowcost); closedgek.lowcost=0; for(j=0;j<g.vexnum;j+) if(g.Rkj<closedgej.lowcost) closedgej.weizhi

12、=k; closedgej.lowcost=g.Rkj; printf("總費(fèi)用為:%dn",money);4.3.2函數(shù)的調(diào)用關(guān)系圖locatevexminimuncreatgraphmainMiniSpanTree_PRIM結(jié)束4.4測(cè)試與分析4.4.1測(cè)試1正確的輸入2錯(cuò)誤的輸入4.4.2分析 調(diào)試過程中遇到的問題及其解決方法 (1)問題: 用for循環(huán)語(yǔ)句控制輸入轄區(qū)名稱及輸出轄區(qū)名稱時(shí)候的個(gè)數(shù)名不對(duì)應(yīng)解決方法: 數(shù)組下標(biāo)時(shí)從零開始的,并且在 for 循環(huán)語(yǔ)句中,循環(huán)變量的執(zhí)行次數(shù)總是比循環(huán)體的執(zhí)行次數(shù)多一次,所以應(yīng)該注意修改使其相對(duì)應(yīng) (2)問題:用循環(huán)控制各轄區(qū)

13、及其之間的距離沒有考慮清楚解決方法:用輸入0 0 0 判定轄區(qū)及其直接距離數(shù)據(jù)輸入完畢 (3)問題:普利姆算法理解不透徹,用其計(jì)算最小生成樹輸出結(jié)果的時(shí)候出現(xiàn)問題 解決方法:上網(wǎng)查閱資料及閱讀課本詢問同學(xué),并在以前程序上加以修改,最終得以運(yùn)行。4.5 附錄#include<stdio.h>#define INF 32767typedef int InfoType;#define MAXV 100typedef structint adj;InfoType *info;ArcCell,AdjMatrixMAXVMAXV;typedef structint edgesMAXVMAXV;

14、int n,e;int vexsMAXV;MGraph;typedef struct ANodeint adjvex;struct ANode *nextarc;InfoType info;ArcNode;typedef int Vertex;typedef struct VnodeVertex data;ArcNode *firstarc;VNode;typedef VNode AdjListMAXV;typedef structAdjList adjlist;int n,e;ALGraph;int sum=0;int Locatevex(MGraph g,int A)int i;for(i

15、=0;i<g.n;i+)if(A=g.vexsi)return i;if(i=g.n)return -1;int CreateMgraph(MGraph &g)int i,j,k,w,v1,v2;printf("請(qǐng)輸入轄區(qū)個(gè)數(shù)和單個(gè)路徑的個(gè)數(shù):n");scanf("%d%d",&g.n,&g.e);printf("輸入各個(gè)轄區(qū)編號(hào):n"); for(i=0;i<g.n;+i)scanf("%d",&g.vexsi); for(i=0;i<g.n;i+)for(j=0

16、;j<g.n;j+)g.edgesij=INF;printf("輸入各轄區(qū)編號(hào)間的路徑長(zhǎng)度:");for(k=0;k<g.e;+k)scanf("%d%d%d",&v1,&v2,&w); i=Locatevex(g,v1); j=Locatevex(g,v2); g.edgesij=g.edgesji=w;return 1;void DispMat(MGraph g)/輸出鄰接矩陣int i,j;for(i=0;i<g.n;i+)for(j=0;j<g.n;j+)if(g.edgesij=INF)print

17、f("%3s","");elseprintf("%3d",g.edgesij);printf("n");void Prim(MGraph g,int v)int lowcostMAXV,min,n=g.n;int closestMAXV,i,j,k;for(i=0;i<n;i+)lowcosti=g.edgesvi;closesti=v;for(i=1;i<n;i+)min=INF;for(j=0;j<n;j+)if(lowcostj!=0&&lowcostj<min)min

18、=lowcostj;k=j;printf("應(yīng)建設(shè)的轄區(qū)(%d,%d)轄區(qū)的花費(fèi)為:%dn",closestk,k,min);if(min!=INF) sum+=min;lowcostk=0;for(j=0;j<n;j+)if(g.edgeskj!=0&&g.edgeskj<lowcostj)lowcostj=g.edgeskj;closestj=k;printf("建設(shè)鐵路線的最低費(fèi)用為:%dn",sum);void main()int i,j;MGraph g;CreateMgraph(g);printf("n");printf("轄區(qū)圖的鄰接矩陣:n");DispMat(g);printf("n");printf("普里姆算法結(jié)果:n");Prim(g,0);printf("n");5 總結(jié)與展望這次課程設(shè)計(jì)任務(wù)是我在大學(xué)以來(lái)的遇到的第一次課程設(shè)計(jì),剛開始看到題目的時(shí)候看起來(lái)不是很難,但是在實(shí)際編程操作中遇到了很多的問題,不過,在不斷地遇到和解決問題的過程中,學(xué)到了很多的知識(shí)。通過這一周的課程設(shè)計(jì),加深了我對(duì)數(shù)據(jù)結(jié)構(gòu)這門課程所學(xué)內(nèi)

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論