版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p> C++程序設(shè)計課程設(shè)計報告</p><p> 課程設(shè)計: 校園導(dǎo)游系統(tǒng) </p><p> 系 別: 計算機(jī)系 年 級: 10級 </p><p> 專 業(yè): 計算機(jī)科學(xué)與技術(shù) </p><p&g
2、t; 班 級: 1班 學(xué) 號: </p><p> 姓 名: </p><p> 成 績: </p><p> 任課教師:
3、 </p><p> 2012 年 8 月 20 日</p><p><b> 目錄</b></p><p> 1.需求分析…………………………………… ……………3</p><p> 2.概要設(shè)計.............................……………………
4、…………3</p><p> 3.詳細(xì)設(shè)計………………………………………………….3</p><p> 4.使用說明………………………………………………….3</p><p> 5.測試結(jié)果……………………………………………….…4</p><p> 6.附錄………………………………………………………5</p><
5、p> 7.參考文獻(xiàn)…………………………………………………14</p><p><b> 需求分析</b></p><p> 設(shè)計一個校園導(dǎo)游程序,為來訪的客人提供各種信息查詢服務(wù)。</p><p><b> 概要設(shè)計</b></p><p> (1) 設(shè)計你所在學(xué)校的校園平面圖,所含
6、景點不少于10個。以圖中頂點表示校內(nèi)各景點,存放景點名稱、代號、簡介等信息;以邊表示路徑,存放路徑長度等相關(guān)信息。</p><p> (2)為來訪客人提供圖中任意景點相關(guān)信息的查詢。</p><p> (3)為來訪客人提供圖中任意景點的問路查詢,即查詢?nèi)我鈨蓚€景點之間的一條最短的簡單路徑。</p><p><b> 詳細(xì)設(shè)計</b><
7、;/p><p> 以輸出流顯示校園的界面</p><p> 以圖的形式存儲校園景點</p><p> 以循環(huán)算法運行操作界面</p><p> 以函數(shù)調(diào)用實現(xiàn)導(dǎo)游功能</p><p><b> 使用說明</b></p><p> 運行時顯示校園景觀圖,同時顯示選擇菜
8、單</p><p> 選擇菜單:1.地點介紹 2.最短路徑 3.結(jié)束 “請選擇功能”</p><p> 地點介紹:出現(xiàn)景點選擇:A.操場 B.偏門 C.圖書館 D.大門 E.食堂 F.誠智樓 G.博學(xué)樓 H.創(chuàng)新樓 I.海天樓 J.明德樓 請選擇地點(選擇加回車即能查詢景點信息)</p><p> 最短路徑:出現(xiàn)“輸入起點位置”,輸入后即出現(xiàn)
9、“輸入終點位置”(輸入加回車即顯示兩景點的最短路徑)</p><p><b> 測試結(jié)果</b></p><p><b> 運行界面</b></p><p><b> 地點介紹</b></p><p><b> 最短路徑</b></p>
10、<p><b> 附錄</b></p><p> 校園景觀圖實現(xiàn)函數(shù):</p><p> void viewshow()</p><p><b> {</b></p><p> cout<<" 東方學(xué)院實景圖
11、"<<endl;</p><p> cout<<""<<endl;</p><p> cout<<" A操場-----B偏門"<<endl;</p><p> cout<<"
12、 / \\"<<endl;</p><p> cout<<" / \\"<<endl;</p><p> cout<<" C圖書館------D大門 E食堂----------\\"<<en
13、dl;</p><p> cout<<" / \\ \\"<<endl;</p><p> cout<<" / \\ F誠智樓---G博學(xué)樓-H創(chuàng)新樓"<<endl;</p&
14、gt;<p> cout<<" / \\/"<<endl;</p><p> cout<<" I海天樓--------J明德樓"<<endl;</p><p> cout<<""<&l
15、t;endl;</p><p><b> }</b></p><p><b> 建立圖函數(shù):</b></p><p> #include"SeqList.h"</p><p> #include"SeqQueue.h"</p><p
16、> const int MaxVertices=10;</p><p> const int MaxWeight=10000;</p><p> class AdjMWGraph</p><p><b> {</b></p><p><b> private:</b></p&g
17、t;<p> SeqList Vertices;//頂點信息的線性表</p><p> int Edge[MaxVertices][MaxVertices];</p><p> int numOfEdges;</p><p><b> public:</b></p><p> AdjMWGraph
18、(const int sz=MaxVertices); </p><p> int GraphEmpty( )const</p><p> {return Vertices.ListEmpty( );}</p><p> int NumOfVertices(void)</p><p> {return Vertices.ListSiz
19、e( );}</p><p> int NumOfEdges(void)</p><p> {return numOfEdges;}</p><p> VerT GetValue(const int i);</p><p> int GetWeight(const int v1,const int v2);</p>&l
20、t;p> void InsertVertex(const VerT &vertex);</p><p> void InsertEdge(const int v1,const int v2,int weight);</p><p> void DeleteVertex(const int i);</p><p> void DeleteEdge
21、(const int v1,const int v2);</p><p> int GetFirstNeighbor(const int v);</p><p> int GetNextNeighbor(const int v1,const int v2);</p><p> void DepthFirstSearch(const int v,int visi
22、ted[],void visit(VerT item)); </p><p> void BroadFirstSearch(const int v,int visited[],void visit(VerT item)); </p><p> void DepthFirstSearch(void visit(VerT item));</p><p> void
23、 BroadFirstSearch(void visit(VerT item));</p><p><b> }; </b></p><p> AdjMWGraph::AdjMWGraph(const int sz)</p><p><b> {</b></p><p> for(int i
24、=0; i<sz; i++)</p><p> for(int j=0; j<sz; j++)</p><p><b> {</b></p><p> if(i == j) Edge[i][j]=0;</p><p> else Edge[i][j]=MaxWeight;</p><
25、;p><b> }</b></p><p> numOfEdges=0;</p><p><b> }</b></p><p> VerT AdjMWGraph::GetValue(const int i)</p><p><b> {</b></p>
26、;<p> if(i<0||i>Vertices.ListSize())</p><p><b> {</b></p><p> cerr<<"參數(shù)i越界出錯!"<<endl;</p><p><b> exit(1);</b></p>
27、;<p><b> }</b></p><p> return Vertices.GetData(i);</p><p><b> }</b></p><p> int AdjMWGraph::GetWeight(const int v1,const int v2)</p><p&
28、gt;<b> {</b></p><p> if(v1<0||v1>Vertices.ListSize()||v2<0||v2>Vertices.ListSize())</p><p><b> {</b></p><p> cerr<<"參數(shù)v1或v2越界出錯!&q
29、uot;<<endl;</p><p><b> exit(1);</b></p><p><b> }</b></p><p> return Edge[v1][v2];</p><p><b> }</b></p><p> v
30、oid AdjMWGraph::InsertVertex(const VerT &vertex)</p><p><b> {</b></p><p> Vertices.Insert(vertex,Vertices.ListSize());</p><p><b> }</b></p><
31、;p> void AdjMWGraph::InsertEdge(const int v1,const int v2,int weight)</p><p><b> {</b></p><p> if(v1<0||v1>Vertices.ListSize()||v2<0||v2> Vertices.ListSize())</p
32、><p><b> {</b></p><p> cerr<<"參數(shù)v1或v2越界出錯!"<<endl;</p><p><b> exit(1);</b></p><p><b> }</b></p><p&
33、gt; Edge[v1][v2]=weight;</p><p> numOfEdges++;</p><p><b> }</b></p><p> void AdjMWGraph::DeleteVertex(const int v)</p><p><b> {</b></p&g
34、t;<p> for(int i=0;i<Vertices.ListSize();i++)</p><p> for(int j=0;j<Vertices.ListSize();j++)</p><p> if((i==v||j==v)&&Edge[i][j]>0 &&Edge[i][j]<MaxWeight)&l
35、t;/p><p><b> {</b></p><p> Edge[i][j]=MaxWeight;</p><p> numOfEdges--;</p><p><b> }</b></p><p> Vertices.Delete(v);</p>&l
36、t;p><b> }</b></p><p> void AdjMWGraph::DeleteEdge(const int v1,const int v2)</p><p><b> {</b></p><p> if(v1<0||v1>Vertices.ListSize()||v2<0||
37、v2>Vertices.ListSize()||v1==v2)</p><p><b> {</b></p><p> cerr<<"參數(shù)v1或v2出錯!"<<endl;</p><p><b> exit(1);</b></p><p>&l
38、t;b> }</b></p><p> Edge[v1][v2]=MaxWeight;</p><p> numOfEdges--;</p><p><b> }</b></p><p> int AdjMWGraph::GetFirstNeighbor(const int v)</p&
39、gt;<p><b> {</b></p><p> if(v<0||v>Vertices.ListSize( ))</p><p><b> {</b></p><p> cerr<<"參數(shù)v1越界出錯!"<<endl;</p>
40、<p><b> exit(1);</b></p><p><b> }</b></p><p> for(int col=0;col<=Vertices.ListSize();col++)</p><p> if(Edge[v][col]>0&&Edge[v][col]<
41、;MaxWeight) return col;</p><p> return -1;</p><p><b> }</b></p><p> int AdjMWGraph::GetNextNeighbor(const int v1,const int v2)</p><p><b> {</b&
42、gt;</p><p> if(v1<0||v1>Vertices.ListSize()||v2<0||v2>Vertices.ListSize())</p><p><b> {</b></p><p> cerr<<"參數(shù)v1或v2越界出錯!"<<endl;</
43、p><p><b> exit(1);</b></p><p><b> }</b></p><p> for(int col=v2+1; col<=Vertices.ListSize(); col++)</p><p> if(Edge[v1][col]>0&&Ed
44、ge[v1][col]<MaxWeight)return col;</p><p> return -1; </p><p><b> }</b></p><p> void AdjMWGraph::DepthFirstSearch(const int v,int visited[],void visit(VerT item))&l
45、t;/p><p><b> {</b></p><p> visit(GetValue(v));</p><p> visited[v]=1;</p><p> int w=GetFirstNeighbor(v);</p><p> while(w!=-1)</p><p
46、><b> {</b></p><p> if(!visited[w])DepthFirstSearch(w,visited,visit);</p><p> w=GetNextNeighbor(v,w);</p><p><b> } </b></p><p><b>
47、}</b></p><p> void AdjMWGraph::BroadFirstSearch(const int v,int visited[],void visit(VerT item))</p><p><b> {</b></p><p><b> VerT u,w;</b></p>
48、<p> SeqQueue queue;//定義隊列queue</p><p> visit(GetValue(v));</p><p> visited[v]=1;</p><p> queue.QInsert(v);</p><p> while(!queue.QueueEmpty())</p>&l
49、t;p><b> {</b></p><p> u=queue.QDelete();</p><p> w=GetFirstNeighbor(u);</p><p> while(w!=-1)</p><p><b> {</b></p><p> if(!
50、visited[w])</p><p><b> {</b></p><p> visit(GetValue(w));</p><p> visited[w]=1;</p><p> queue.QInsert(w);</p><p><b> }</b></
51、p><p> w=GetNextNeighbor(u,w);</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> void AdjMWGraph::DepthFirst
52、Search(void visit(VerT item))</p><p><b> {</b></p><p> int *visited=new int[NumOfVertices()];</p><p> for(int i=0;i<NumOfVertices();i++)visited[i]=0;</p>&l
53、t;p> for(i=0;i<NumOfVertices();i++)</p><p> if(!visited[i])DepthFirstSearch(i,visited,visit);</p><p> delete []visited;</p><p><b> } </b></p><p>
54、 //非連通圖的廣度優(yōu)先搜索遍歷算法如下</p><p> void AdjMWGraph::BroadFirstSearch(void visit(VerT item))</p><p><b> {</b></p><p> int *visited=new int[NumOfVertices()];</p><p
55、> for(int i=0;i<NumOfVertices();i++)visited[i]=0;</p><p> for(i=0; i<NumOfVertices(); i++)</p><p> if(!visited[i]) BroadFirstSearch(i,visited,visit);</p><p> delete []v
56、isited;</p><p><b> }</b></p><p> struct RowColWeight</p><p><b> {</b></p><p><b> int row;</b></p><p><b> int
57、 col;</b></p><p> int weight;</p><p><b> };</b></p><p> void CreatGraph(AdjMWGraph &G,Datatype V[],int n,RowColWeight E[],int e)//建圖</p><p><
58、;b> {</b></p><p> for(int i=0; i<n;i++)G.InsertVertex(V[i]);</p><p> for(int k=0; k<e;k++)G.InsertEdge(E[k].row,E[k].col,E[k].weight);</p><p><b> }</b>
59、;</p><p> void Printchar(char item)</p><p><b> {</b></p><p> cout << item<<" ";</p><p><b> } </b></p><p>
60、 void Dijkstra(AdjMWGraph &G,int v0,int distance[],int path[])</p><p><b> {</b></p><p> int n=G.NumOfVertices();</p><p> int *s=new int[n];</p><p>
61、 int minDis,i,j,u;</p><p> for(i=0;i<n;i++)</p><p><b> {</b></p><p> distance[i]=G.GetWeight(v0,i);</p><p><b> s[i]=0;</b></p><
62、;p> if(i!=v0&&distance[i]<MaxWeight)path[i]=v0;</p><p> else path[i]=-1;</p><p><b> }</b></p><p><b> s[v0]=1;</b></p><p> for
63、(i=1;i<n;i++)</p><p><b> {</b></p><p> minDis=MaxWeight;</p><p> for(j=0;j<=n;j++)</p><p> if(s[j]==0&&distance[j]<minDis)</p>&
64、lt;p><b> {</b></p><p><b> u=j;</b></p><p> minDis=distance[j];</p><p><b> }</b></p><p> if(minDis==MaxWeight)return;</p&g
65、t;<p><b> s[u]=1;</b></p><p> for(j=0;j<n;j++)</p><p> if(s[j]==0&&G.GetWeight(u,j)<MaxWeight&&distance[u]+G.GetWeight(u,j)<distance[j])</p>
66、<p><b> {</b></p><p> distance[j]=distance[u]+G.GetWeight(u,j);</p><p> path[j]=u;</p><p><b> }</b></p><p><b> }</b></
67、p><p><b> }</b></p><p><b> 主函數(shù):</b></p><p> typedef char VerT;</p><p> typedef char Datatype;</p><p> #include"AdjMWGraph.h&
68、quot;</p><p> #include"View.h"</p><p> int main()</p><p><b> { </b></p><p> int s,sss=1,j=1;</p><p> char ch,qd,zd;</p>&
69、lt;p> AdjMWGraph g;</p><p> char a[]={'A','B','C','D','E','F','G','H','I','J'};</p><p> RowColWeight rcw[]={
70、{0,1,20},{0,3,30},{0,4,30},{1,0,20},{2,3,20},{3,0,30},{3,2,20},{3,8,30},{3,9,20},{4,0,30},{4,6,20},{5,6,15},{5,9,15},{6,4,20},{6,5,15},{6,7,10},{7,6,10},{8,3,30},{8,9,15},{9,5,15},{9,8,15}}; </p><p> int n=
71、10,e=24;</p><p> CreatGraph(g,a,n,rcw,e);</p><p> int m=g.NumOfVertices();</p><p> int *distance=new int[m];</p><p> int *path=new int[m];</p><p> int
72、 v0=0,v1;</p><p> Dijkstra(g,v0,distance,path);</p><p><b> end:</b></p><p> if (j==0){system("cls");}</p><p><b> do{</b></p>
73、<p> viewshow();</p><p> cout<<"1.地點介紹 2.最短路徑 3.結(jié)束"<<endl<<"請選擇功能:";</p><p><b> cin>>s;</b></p><p> system("
74、cls");</p><p><b> if(s==1)</b></p><p><b> {</b></p><p><b> do {</b></p><p> viewshow();</p><p> cout<<&
75、quot;A.操場 B.偏門 C.圖書館 D.大門 E.食堂"<<endl</p><p> <<"F.誠智樓 G.博學(xué)樓 H.創(chuàng)新樓 I.海天樓 J.明德樓 "<<endl<<"請選擇地點:";</p><p><b> cin>>ch;</
76、b></p><p> switch(ch)</p><p><b> {</b></p><p><b> case 'A':</b></p><p> zhengdamenshow();</p><p> cin.get();</p&
77、gt;<p> cin.get();</p><p> system("cls");break;</p><p><b> case 'B':</b></p><p><b> mdshow();</b></p><p> cin.get(
78、);</p><p> cin.get();</p><p> system("cls");break;</p><p><b> case 'C':</b></p><p><b> czshow();</b></p><p>
79、 cin.get();</p><p> cin.get();</p><p> system("cls");break;</p><p><b> case 'D':</b></p><p><b> bxshow();</b></p>&
80、lt;p> cin.get();</p><p> cin.get();</p><p> system("cls");break;</p><p><b> case 'E':</b></p><p><b> cxshow();</b><
81、/p><p> cin.get();</p><p> cin.get();</p><p> system("cls");break;</p><p><b> case 'F':</b></p><p> bahaoshow();</p>
82、<p> cin.get();</p><p> cin.get();</p><p> system("cls");break;</p><p><b> case 'G':</b></p><p> sitangshow();</p><p
83、> cin.get();</p><p> cin.get();</p><p> system("cls");break;</p><p><b> case 'H':</b></p><p> shihaoshow();</p><p>
84、cin.get();</p><p> cin.get();</p><p> system("cls");break;</p><p><b> case 'I':</b></p><p> caochangshow();</p><p> cin.
85、get();</p><p> cin.get();</p><p> system("cls");break; </p><p><b> case 'J':</b></p><p> tushuguanshow();</p><p> cin.
86、get();</p><p> cin.get();</p><p> system("cls");break;</p><p><b> case'K':</b></p><p><b> j=0;</b></p><p><
87、;b> goto end;</b></p><p><b> default:</b></p><p> cout<<"選擇有誤,請重新選擇!"<<endl;</p><p> cin.get();</p><p> cin.get();</p
88、><p> system("cls");</p><p><b> }</b></p><p> } while(1);</p><p><b> }</b></p><p><b> if(s==2)</b></p>
89、;<p><b> {</b></p><p><b> do {</b></p><p> viewshow();</p><p><b> QIDIAN:</b></p><p> cout<<"請輸入起點位置:";&
90、lt;/p><p><b> cin>>qd;</b></p><p> if (qd=='A')v0=0;</p><p> else if(qd=='B')v0=1;</p><p> else if(qd=='C')v0=2;</p>&
91、lt;p> else if(qd=='D')v0=3;</p><p> else if(qd=='E')v0=4;</p><p> else if(qd=='F')v0=5;</p><p> else if(qd=='G')v0=6;</p><p> el
92、se if(qd=='H')v0=7;</p><p> else if(qd=='I')v0=8;</p><p> else if(qd=='J')v0=9;</p><p> else {cout<<"起點輸入有誤,請重新輸入!"<<endl;cin.get();
93、cin.get();system("cls");goto QIDIAN;}</p><p> cout<<"請輸入終點位置:";</p><p><b> cin>>zd;</b></p><p> if (zd=='A')v1=0;</p>&
94、lt;p> else if(zd=='B')v1=1;</p><p> else if(zd=='C')v1=2;</p><p> else if(zd=='D')v1=3;</p><p> else if(qd=='E')v1=4;</p><p> el
95、se if(zd=='F')v1=5;</p><p> else if(zd=='G')v1=6;</p><p> else if(zd=='H')v1=7;</p><p> else if(zd=='I')v1=8;</p><p> else if(zd==
96、39;J')v1=9;</p><p> else {cout<<"終點輸入有誤,請重新輸入!"<<endl;cin.get();cin.get();system("cls");goto QIDIAN;}</p><p> cout<<"起點"<<g.GetValue(v
97、0)<<"到終點"<<g.GetValue(v1)<<"的最短距離為:"<<distance[v1]<<endl;</p><p> cout<<"是否繼續(xù)查詢:1.是 2.否;請選擇:";</p><p><b> cin>>ss
98、s;</b></p><p> system("cls");</p><p> }while(sss==1);</p><p><b> }</b></p><p> if (s==3){cout<<"謝謝使用!"<<endl;retur
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- c語言校園導(dǎo)游系統(tǒng)課程設(shè)計
- 校園導(dǎo)游系統(tǒng)課程設(shè)計報告
- 校園導(dǎo)游系統(tǒng)課程設(shè)計報告
- 校園導(dǎo)游咨詢系統(tǒng)課程設(shè)計
- 校園導(dǎo)游課程設(shè)計
- 航空售票系統(tǒng)+c++課程設(shè)計
- c++酒店管理系統(tǒng)課程設(shè)計
- c++酒店管理系統(tǒng)課程設(shè)計
- c++課程設(shè)計——飛機(jī)訂票系統(tǒng)
- 銷售管理系統(tǒng)c++課程設(shè)計
- 《c++》課程設(shè)計倉庫管理系統(tǒng)
- c++課程設(shè)計-學(xué)生管理系統(tǒng)
- c++學(xué)生管理系統(tǒng)課程設(shè)計
- c++課程設(shè)計--酒店管理系統(tǒng)
- 校園導(dǎo)游系統(tǒng)程序__課程設(shè)計_報告
- c++課程設(shè)計報告
- c++課程設(shè)計ppt
- c++課程設(shè)計--基于c++的火車票管理系統(tǒng)
- c++課程設(shè)計--圖書管理系統(tǒng)
- 人事考勤管理系統(tǒng)c++課程設(shè)計
評論
0/150
提交評論