課程設(shè)計報告-- 小區(qū)網(wǎng)絡(luò)光纖的鋪設(shè)_第1頁
已閱讀1頁,還剩14頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  課程設(shè)計報告</b></p><p><b>  課程設(shè)計的主要內(nèi)容</b></p><p>  設(shè)計數(shù)據(jù)結(jié)構(gòu)和算法,實現(xiàn)居民小區(qū)之間網(wǎng)絡(luò)光纖鋪設(shè)的最佳方案選擇,主要內(nèi)容如下:需要在某個城市n個居民小區(qū)之間鋪設(shè)網(wǎng)絡(luò)光纖,假設(shè)任意兩個居民小區(qū)之間均需要鋪設(shè)光纖,則在這n個居民小區(qū)之間只需要鋪設(shè)n-1條光纖即可形成一個網(wǎng)

2、絡(luò),但由于地理環(huán)境不同,所需要的代價也不盡相同。本課程設(shè)計要求事先隨機生成任意居民小區(qū)之間鋪設(shè)網(wǎng)絡(luò)光纖的代價,并將代價存入文件,然后設(shè)計一個最佳方案進行光纖鋪設(shè),使得既能連通所有小區(qū)之間的網(wǎng)絡(luò),又能使網(wǎng)絡(luò)光纖鋪設(shè)的代價最小,最終以圖形形式輸出所設(shè)計的最佳方案。</p><p><b>  功能和結(jié)構(gòu)設(shè)計</b></p><p>  1、克魯斯卡爾算法:</p&g

3、t;<p>  克魯斯卡爾算法的思想:</p><p>  設(shè)無向連通網(wǎng)為G=(V,E),令G的最小生成樹為T=(U,TE),其初態(tài)為U=V,TE={},這樣T中個頂點各自構(gòu)成一個連通分量。然后,按照邊的權(quán)值由小到大的順序,依次考察邊集E中的各條邊。若被考察邊的兩個頂點屬于T的兩個不同的連通分量,則將此邊加入到TE中,同時把兩個連通分量連接為一個連通分量;若被考察邊的兩個頂點屬于同一個連通分量,則舍

4、去此邊,以免造成回路,如此下來,當(dāng)T中的連通分量個數(shù)為1時,此連通分量便為G的一棵最小生成樹。</p><p><b>  算法過程描述:</b></p><p>  初始化:U=V; TE={};</p><p>  重復(fù)下述操作直到T中的連通分量個數(shù)為1;</p><p>  2、1 在E中尋找最短邊(U,V);

5、</p><p>  2、2 如果頂點u、v位于T的兩個不同連通分量,則</p><p>  2 . 2 . 1、 將邊(u、v)并入TE;</p><p>  2 . 2 . 2、 將這兩個連通分量合為一個;</p><p>  2、3 在E中標記邊(u,v),使得(u,v)不參加后續(xù)最短邊的選取;</p><p&g

6、t;<b>  模塊分析</b></p><p>  根據(jù)對模型的功能分析,該管道鋪設(shè)設(shè)計可以具有以下功能:</p><p>  網(wǎng)絡(luò)光纖鋪設(shè)信息的輸入;</p><p>  最小生成樹信息的輸出;</p><p><b>  抽象數(shù)據(jù)類型分析</b></p><p>  V

7、ertex[] 居民區(qū)</p><p>  Edge[][] 鄰接矩陣儲存居民區(qū)的關(guān)系</p><p>  R[] 居民區(qū)之間的距離</p><p>  vertexNum 表示居民區(qū)數(shù)量</p><p>  edgeNum 表示居民區(qū)的路線數(shù)目</p><p><b&g

8、t;  功能分析</b></p><p><b>  信息輸入:</b></p><p><b>  程序輸出:</b></p><p><b>  最短路徑:</b></p><p><b>  流程圖和算法設(shè)計</b></p>

9、<p><b>  //居民區(qū)數(shù)據(jù)輸入</b></p><p>  cout<<"請輸入居民區(qū)的個數(shù):";</p><p>  cin>>vertexNum;</p><p>  cout<<endl;</p><p>  cout<<&qu

10、ot;分別輸入居民區(qū):";</p><p>  for(i=0;i<vertexNum;i++)</p><p>  cin>>vertex[i];</p><p>  cout<<"請輸入網(wǎng)絡(luò)光纖鋪設(shè)路線的總條數(shù):";</p><p>  cin>>edgeNum;&l

11、t;/p><p>  //二維數(shù)組存儲居民區(qū)信息</p><p>  cout<<"請按此格式輸入邊和權(quán)值:n, m, k( 表示 n 居民區(qū)到 m 居民區(qū)的距離為 k 米):"<<endl;</p><p>  for(i=0;i<edgeNum;i++)</p><p><b>  

12、{</b></p><p>  cin>>n>>m>>k;</p><p>  Edge[n][m]=k;</p><p>  Edge[m][n]=k;</p><p><b>  R[i]=k;</b></p><p><b>  }&

13、lt;/b></p><p>  cout<<endl;</p><p>  //對儲存權(quán)值的數(shù)組R[]進行排序</p><p>  void Graph<Datatype>::InsertSort()</p><p><b>  {</b></p><p><

14、b>  int k;</b></p><p>  for(int i=1;i<edgeNum;i++)</p><p><b>  {</b></p><p><b>  k=R[i];</b></p><p>  for(int j=i-1;k<R[j];j--)&l

15、t;/p><p>  {R[j+1]=R[j];}</p><p><b>  R[j+1]=k;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  //克魯卡爾算法生成最小生成樹</p>

16、<p>  void Graph<Datatype>::Kruskal()</p><p><b>  {</b></p><p><b>  Sum=0;</b></p><p>  int i,b=0,d=0,num,vex1,vex2;</p><p>  for(i

17、=0;i<vertexNum;i++)</p><p>  parent[i]=-1;</p><p>  cout<<"選取光纖鋪設(shè)路線:"<<endl;</p><p>  for(num=0,i=0;i<edgeNum;i++)</p><p><b>  {</b

18、></p><p>  vex1=FindRoot(parent,edge[i].from);</p><p>  vex2=FindRoot(parent,edge[i].to);</p><p>  if(vex1!=vex2)</p><p><b>  {</b></p><p> 

19、 parent[vex1]=vex2;</p><p><b>  num++;</b></p><p>  cout<<"從居民區(qū)"<<edge[i].from<<"到"<<"居民區(qū)"<<edge[i].to<<",路徑長度為

20、:"<<edge[i].weight<<" 米"<<endl;</p><p>  edgeP[d].from=edge[i].from;</p><p>  edgeP[d].to=edge[i].to;</p><p><b>  d++;</b></p>&l

21、t;p>  Sum=Sum+edge[i].weight;</p><p>  if(num==vertexNum-1)return;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p>

22、;<p><b>  流程圖:</b></p><p><b>  N</b></p><p><b>  Y</b></p><p><b>  源程序代碼</b></p><p>  #ifndef Graph_H</p>

23、<p>  #define Graph_H</p><p>  const int MaxVertex=10;</p><p>  const int MaxEdge=100;</p><p>  struct EdgeType</p><p><b>  {</b></p><p> 

24、 int from,to;</p><p>  int weight;</p><p><b>  };</b></p><p>  template<class Datatype></p><p>  class Graph</p><p><b>  {</b>

25、;</p><p><b>  public:</b></p><p><b>  Graph();</b></p><p>  ~Graph(){}</p><p>  void Kruskal();</p><p>  void InsertSort();</p&g

26、t;<p>  void BubbleSort1();</p><p>  int FindRoot(int a[],int n);</p><p>  void outSum();</p><p>  void Price();</p><p>  void Print();</p><p><b

27、>  private:</b></p><p>  Datatype vertex[MaxVertex];</p><p>  int Edge[MaxVertex][MaxVertex];</p><p>  EdgeType edge[MaxEdge];</p><p>  EdgeType edgeP[MaxEdge]

28、;</p><p>  int parent[MaxVertex];</p><p>  int vertexNum,edgeNum;</p><p>  int R[MaxEdge];</p><p><b>  int Sum;</b></p><p>  int price;</p&g

29、t;<p><b>  };</b></p><p><b>  #endif</b></p><p>  #include<iostream></p><p>  using namespace std;</p><p>  #include "Graph.h&

30、quot;</p><p>  #include<graphics.h></p><p>  #include<conio.h></p><p>  #include <string></p><p>  #include<iomanip></p><p>  #incl

31、ude <fstream></p><p>  template<class Datatype></p><p>  Graph<Datatype>::Graph()</p><p><b>  {</b></p><p><b>  getch();</b>&l

32、t;/p><p>  int i,j,k,n,m;</p><p>  cout<<"請輸入居民區(qū)的個數(shù):";</p><p>  cin>>vertexNum;</p><p>  cout<<endl;</p><p>  cout<<"分別

33、輸入居民區(qū):";</p><p>  for(i=0;i<vertexNum;i++)</p><p>  cin>>vertex[i];</p><p>  cout<<"生成居民區(qū)序號表:"<<endl;</p><p>  cout<<"┏━━

34、━";</p><p>  for(int g=0;g<vertexNum;g++){cout<<"┳━━━";}cout<<"┓"<<endl;</p><p>  cout<<"┃"<<left<<setw(6)<<"

35、居民區(qū)";</p><p>  for(int h=0;h<vertexNum;h++)</p><p>  {cout<<"┃"<<setw(6)<<vertex[h];}cout<<"┃"<<endl;</p><p>  cout<<

36、"┣━━━";</p><p>  for(int e=0;e<vertexNum;e++){cout<<"╋━━━";}cout<<"┫"<<endl;</p><p>  cout<<"┃"<<left<<setw(6)<&

37、lt;"序號";</p><p>  for(int f=0;f<vertexNum;f++){cout<<"┃"<<setw(6)<<f;}cout<<"┃"<<endl;</p><p>  cout<<"┗━━━";</p

38、><p>  for(int t=0;t<vertexNum;t++){cout<<"┻━━━";}cout<<"┛"<<endl;</p><p><b>  getch();</b></p><p>  cout<<endl;</p>&

39、lt;p>  cout<<"請輸入網(wǎng)絡(luò)光纖鋪設(shè)路線的總條數(shù):";</p><p>  cin>>edgeNum;</p><p>  cout<<endl;</p><p>  if(edgeNum>vertexNum*(vertexNum-1)/2)</p><p><

40、;b>  {</b></p><p><b>  int c;</b></p><p>  cout<<"輸入條數(shù)有誤,請重新輸入!"<<endl;</p><p><b>  cin>>c;</b></p><p>  ed

41、geNum=c;</p><p><b>  }</b></p><p>  for(i=0;i<MaxVertex;i++)</p><p>  for(j=0;j<MaxVertex;j++)</p><p>  Edge[i][j]=0;</p><p>  cout<&l

42、t;"請按此格式輸入邊和權(quán)值:n, m, k( 表示 n 居民區(qū)到 m 居民區(qū)的距離為 k 米):"<<endl;</p><p>  for(i=0;i<edgeNum;i++)</p><p><b>  {</b></p><p>  cin>>n>>m>>k;&l

43、t;/p><p>  Edge[n][m]=k;</p><p>  Edge[m][n]=k;</p><p><b>  R[i]=k;</b></p><p><b>  }</b></p><p>  cout<<endl;</p><p&

44、gt;<b>  }</b></p><p>  template<class Datatype></p><p>  void Graph<Datatype>::InsertSort()</p><p><b>  {</b></p><p><b>  int

45、k;</b></p><p>  for(int i=1;i<edgeNum;i++)</p><p><b>  {</b></p><p><b>  k=R[i];</b></p><p>  for(int j=i-1;k<R[j];j--)</p>&

46、lt;p>  {R[j+1]=R[j];}</p><p><b>  R[j+1]=k;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  template<class Datatype></p

47、><p>  void Graph<Datatype>::BubbleSort1()</p><p><b>  {</b></p><p>  int count=0;</p><p>  while(count!=edgeNum)</p><p><b>  {</b&

48、gt;</p><p>  for(int i=0;i<vertexNum;i++)</p><p>  for(int j=i;j<vertexNum;j++)</p><p><b>  {</b></p><p>  if(Edge[i][j]==R[count])</p><p&g

49、t;<b>  {</b></p><p>  edge[count].from=i;</p><p>  edge[count].to=j;</p><p>  edge[count].weight=R[count];</p><p><b>  count++;</b></p>

50、<p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  template<class Datatype></p&

51、gt;<p>  void Graph<Datatype>::Kruskal()</p><p><b>  {</b></p><p><b>  Sum=0;</b></p><p>  int i,b=0,d=0,num,vex1,vex2;</p><p>  fo

52、r(i=0;i<vertexNum;i++)</p><p>  parent[i]=-1;</p><p>  cout<<"選取光纖鋪設(shè)路線:"<<endl;</p><p>  for(num=0,i=0;i<edgeNum;i++)</p><p><b>  {<

53、;/b></p><p>  vex1=FindRoot(parent,edge[i].from);</p><p>  vex2=FindRoot(parent,edge[i].to);</p><p>  if(vex1!=vex2)</p><p><b>  {</b></p><p&g

54、t;  parent[vex1]=vex2;</p><p><b>  num++;</b></p><p>  cout<<"從居民區(qū)"<<edge[i].from<<"到"<<"居民區(qū)"<<edge[i].to<<",路徑

55、長度為:"<<edge[i].weight<<" 米"<<endl;</p><p>  edgeP[d].from=edge[i].from;</p><p>  edgeP[d].to=edge[i].to;</p><p><b>  d++;</b></p>

56、<p>  Sum=Sum+edge[i].weight;</p><p>  if(num==vertexNum-1)return;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p

57、><p>  template<class Datatype></p><p>  int Graph<Datatype>::FindRoot(int parent[],int v)</p><p><b>  {</b></p><p><b>  int t=v;</b>&l

58、t;/p><p>  if(parent[t]>-1) t=parent[t];</p><p><b>  return t;</b></p><p><b>  }</b></p><p>  template<class Datatype></p><p>

59、;  void Graph<Datatype>::outSum()</p><p><b>  {</b></p><p>  cout<<endl;</p><p>  cout<<"這 "<<vertexNum<<" 個居民區(qū)之間鋪設(shè)網(wǎng)絡(luò)光纖總長度中最

60、短的長度為:"<<Sum<<" 米"<<endl;</p><p>  cout<<endl;</p><p><b>  }</b></p><p>  template<class Datatype></p><p>  voi

61、d Graph<Datatype>::Price()</p><p><b>  {</b></p><p>  cout<<"請輸入單位長度路線鋪設(shè)的價格(元):";</p><p>  cin>>price;</p><p>  cout<<endl

62、;</p><p>  cout<<"所以,這 "<<vertexNum<<" 個居民區(qū)之間鋪設(shè)網(wǎng)絡(luò)光纖所需最小費用為:"<<Sum*price<<" 元"<<endl;</p><p><b>  }</b></p>&l

63、t;p>  template<class Datatype></p><p>  void Graph<Datatype>::Print()</p><p><b>  {</b></p><p>  int x1,x2,y1,y2;</p><p>  initgraph(500,500)

64、;</p><p>  if(vertexNum>0){</p><p>  circle(100,200,25);</p><p>  outtextxy(100,200,vertex[0]);</p><p>  if(vertexNum>1){</p><p>  circle(250,100,25)

65、;</p><p>  outtextxy(250,100,vertex[1]);</p><p>  if(vertexNum>2){</p><p>  circle(150,350,25);</p><p>  outtextxy(150,350,vertex[2]);</p><p>  if(verte

66、xNum>3){</p><p>  circle(350,350,25);</p><p>  outtextxy(350,350,vertex[3]);</p><p>  if(vertexNum>4){</p><p>  circle(400,200,25);</p><p>  outtextx

67、y(400,200,vertex[4]);</p><p>  if(vertexNum>5)circle(250,250,25);</p><p>  outtextxy(250,250,vertex[5]);}}}}}</p><p>  for(int n=0,k=0;k<edgeNum;k++)</p><p><b

68、>  {</b></p><p>  switch(edgeP[n].from)</p><p><b>  {</b></p><p>  case 0:{x1=100;y1=200;}break;</p><p>  case 1:{x1=250;y1=100;}break;</p>

69、<p>  case 2:{x1=150;y1=350;}break;</p><p>  case 3:{x1=350;y1=350;}break;</p><p>  case 4:{x1=400;y1=200;}break;</p><p>  case 5:{x1=250;y1=250;}break;</p><p><

70、;b>  }</b></p><p>  switch(edgeP[n].to)</p><p><b>  {</b></p><p>  case 0:{x2=100;y2=200;}break;</p><p>  case 1:{x2=250;y2=100;}break;</p>

71、<p>  case 2:{x2=150;y2=350;}break;</p><p>  case 3:{x2=350;y2=350;}break;</p><p>  case 4:{x2=400;y2=200;}break;</p><p>  case 5:{x2=250;y2=250;}break;</p><p><

72、;b>  }</b></p><p>  line(x1,y1,x2,y2);</p><p><b>  n++;</b></p><p><b>  }</b></p><p><b>  getch();</b></p><p>

73、  closegraph();</p><p><b>  }</b></p><p>  #include<iostream></p><p>  using namespace std;</p><p>  #include "Graph.cpp"</p><p&g

74、t;  #include<graphics.h></p><p>  #include<conio.h></p><p>  int main()</p><p><b>  {</b></p><p><b>  int a1;</b></p><p&g

75、t;  for(a1=0;a1<25;a1++) </p><p>  cout<<" "; </p><p>  cout<<"網(wǎng)絡(luò)光纖鋪設(shè)的最佳方案選擇"<<endl; </p><p>  for(a1=0;a1<21;a1++) </p><p>

76、  cout<<" "; </p><p>  for(a1=0;a1<34;a1++) </p><p>  cout<<"*"; </p><p>  cout<<endl; </p><p>  for(a1=0;a1<21;a1++) <

77、/p><p>  cout<<" "; </p><p>  cout<<"* *"<<endl;</p><p>  for(a1=0;a1<21;a1++) </p><p>  cout<

78、<" "; </p><p>  cout<<"* 歡迎使用本程序,希望本程序可以 *"; </p><p>  cout<<endl; </p><p>  for(a1=0;a1<21;a1++) </p><p>  cout<<" &

79、quot;; </p><p>  cout<<"* 幫您選擇最佳鋪設(shè)方案 *"; </p><p>  cout<<endl; </p><p>  for(a1=0;a1<21;a1++) </p><p>  cout<<" ";&

80、lt;/p><p>  cout<<"* *"; </p><p>  cout<<endl; </p><p>  for(a1=0;a1<21;a1++) </p><p>  cout<<" "

81、;</p><p>  for(a1=0;a1<34;a1++)</p><p>  cout<<"*";</p><p>  cout<<endl;</p><p>  Graph<char>G;</p><p>  G.InsertSort();<

82、/p><p>  G.BubbleSort1();</p><p>  G.Kruskal();</p><p>  G.outSum();</p><p>  G.Price ();</p><p><b>  getch();</b></p><p>  G.Print (

83、);</p><p>  cout<<endl;</p><p>  for(a1=0;a1<15;a1++) </p><p>  cout<<" "; </p><p>  for(a1=0;a1<25;a1++) </p><p>  cout<<

84、;"*"; </p><p>  cout<<endl; </p><p>  for(a1=0;a1<15;a1++) </p><p>  cout<<" "; </p><p>  cout<<"* 謝 謝 您 的 使 用 ! *&qu

85、ot;<<endl; </p><p>  for(a1=0;a1<15;a1++) </p><p>  cout<<" ";</p><p>  for(a1=0;a1<25;a1++)</p><p>  cout<<"*";</p>

86、<p>  cout<<endl;</p><p><b>  return 0;</b></p><p><b>  }</b></p><p><b>  課程設(shè)計總結(jié)</b></p><p>  經(jīng)過兩個多星期的不懈努力,我們小組終于完成本次課程

87、設(shè)計一一《網(wǎng)絡(luò)光纖鋪設(shè)的最佳方案選擇》,我們選用克魯斯卡爾算法進行程序設(shè)計。首先,我們對程序的大概框架進行構(gòu)想,設(shè)計好基本的邏輯框架,然后針對克魯斯卡爾算法進行程序編寫,對于高級程序員來說,雖然bug可以使程序崩潰,但他們依然可以閑庭信步般把問題解決,可是對于我們這些正在成長中的初級程序員來說,那就是一個災(zāi)難,需要我們一起扛才能度過難關(guān),于是我們的合作精神就被發(fā)揮得淋漓盡致了,不管對外還是對內(nèi),我們這些菜鳥程序員都是一家子,處理分析問題

88、就跟快,完成了編寫,再經(jīng)過多次的調(diào)試,終于完成本次程序設(shè)計。</p><p>  通過本次程序設(shè)計,使我們對本學(xué)期學(xué)習(xí)的數(shù)據(jù)結(jié)構(gòu)有了進一步的了解,鞏固上一學(xué)年所學(xué)的知識;而且,我們對程序設(shè)計的算法有了基本的認識,同時,讓我們知道算法對于一個程序來說是非常重要的,好的程序就應(yīng)該要用好的算法;本次課程設(shè)計中涉及到圖形的處理,但我們對于圖形是一無所知的,經(jīng)過在多種渠道的查閱,最后通過使用C++圖形庫EasyX實現(xiàn)圖形處

89、理。</p><p>  本次程序設(shè)計使我們學(xué)會了很多,鞏固課本所學(xué)的知識的同時,也掌握一些課外的有關(guān)程序設(shè)計的知識,希望以后能夠編寫出更好的程序!</p><p><b>  參考資料</b></p><p>  1、胡明 《數(shù)據(jù)結(jié)構(gòu)》(C++版) 清華大學(xué)出版社</p><p>  2、張勇 《C++語

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論