數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)—迷宮問(wèn)題_第1頁(yè)
已閱讀1頁(yè),還剩18頁(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、<p><b>  課程設(shè)計(jì)說(shuō)明書(shū)</b></p><p><b>  課程設(shè)計(jì)任務(wù)書(shū)</b></p><p>  課程名稱(chēng):數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</p><p><b>  一、課程設(shè)計(jì)的題目</b></p><p><b>  迷宮問(wèn)題</b>&

2、lt;/p><p><b>  二、設(shè)計(jì)內(nèi)容</b></p><p><b>  1、迷宮問(wèn)題</b></p><p><b>  問(wèn)題描述:</b></p><p>  以一個(gè)m*n的長(zhǎng)方陣表示迷宮,0和1分別表示迷宮中的通路和障礙。迷宮問(wèn)題要求求出從入口(1,1)到出口(m,n

3、)的一條通路,或得出沒(méi)有通路的結(jié)論。</p><p><b>  基本要求:</b></p><p>  首先實(shí)現(xiàn)一個(gè)以鏈表作存儲(chǔ)結(jié)構(gòu)的棧類(lèi)型,然后編寫(xiě)一個(gè)求迷宮問(wèn)題的非遞歸程序,求得的通路以三元組(i,j,d)的形式輸出,其中:(i,j)指示迷宮中的一個(gè)坐標(biāo), d表示走到下一坐標(biāo)的方向。</p><p><b>  測(cè)試數(shù)據(jù):<

4、;/b></p><p>  左上角(1,1)為入口,右下角(m,n)為出口。</p><p><b>  選作內(nèi)容:</b></p><p> ?。?)編寫(xiě)遞歸形式的算法,求得迷宮中的所有可能的通路</p><p>  (2)以方陣的形式輸出迷宮及其通路迷宮中的所有可能的通路</p><p&g

5、t;  設(shè)計(jì)工作量:40課時(shí)</p><p><b>  工作計(jì)劃:</b></p><p><b>  見(jiàn)課表</b></p><p>  指導(dǎo)教師簽名:         日期:        </p><p>  教研室主任簽名:        日期:        </p>&

6、lt;p>  系主任簽名:          日期:        </p><p>  長(zhǎng)沙學(xué)院課程設(shè)計(jì)鑒定表</p><p><b>  摘 要</b></p><p>  計(jì)算機(jī)系的課程設(shè)計(jì),我設(shè)計(jì)了一個(gè)迷宮系統(tǒng),利用了棧結(jié)構(gòu)來(lái)保存所走的迷宮路徑,可以實(shí)現(xiàn)尋找迷宮通路的功能,當(dāng)無(wú)法找到出口時(shí),可提示用戶不存在路徑。</p&

7、gt;<p>  迷宮的地圖可由手動(dòng)輸入,包括迷宮的行數(shù)與列數(shù)、迷宮的具體布局。</p><p>  關(guān)鍵詞:課程設(shè)計(jì);迷宮;數(shù)據(jù)結(jié)構(gòu)。</p><p><b>  目錄</b></p><p>  1.設(shè)計(jì)內(nèi)容與要求1</p><p><b>  2.設(shè)計(jì)說(shuō)明2</b></

8、p><p><b>  2.1界面設(shè)計(jì)2</b></p><p>  2.2 數(shù)據(jù)結(jié)構(gòu)3</p><p><b>  3.實(shí)現(xiàn)與測(cè)試4</b></p><p><b>  3.1結(jié)果4</b></p><p><b>  3.2測(cè)試過(guò)程5

9、</b></p><p><b>  總結(jié)7</b></p><p><b>  參考文獻(xiàn)8</b></p><p><b>  附錄A 源代碼9</b></p><p><b>  1.設(shè)計(jì)內(nèi)容與要求</b></p>&l

10、t;p><b>  設(shè)計(jì)要求:</b></p><p><b>  問(wèn)題描述:</b></p><p>  以一個(gè)m*n的長(zhǎng)方陣表示迷宮,0和1分別表示迷宮中的通路和障礙。迷宮問(wèn)題要求求出從入口(1,1)到出口(m,n)的一條通路,或得出沒(méi)有通路的結(jié)論。</p><p><b>  基本要求:</b&

11、gt;</p><p>  首先實(shí)現(xiàn)一個(gè)以鏈表作存儲(chǔ)結(jié)構(gòu)的棧類(lèi)型,然后編寫(xiě)一個(gè)求迷宮問(wèn)題的非遞歸程序,求得的通路以三元組(i,j,d)的形式輸出,其中:(i,j)指示迷宮中的一個(gè)坐標(biāo), d表示走到下一坐標(biāo)的方向。</p><p><b>  測(cè)試數(shù)據(jù):</b></p><p>  左上角(1,1)為入口,右下角(m,n)為出口。</p&g

12、t;<p><b>  選作內(nèi)容:</b></p><p>  (1)編寫(xiě)遞歸形式的算法,求得迷宮中的所有可能的通路</p><p> ?。?)以方陣的形式輸出迷宮及其通路迷宮中的所有可能的通路</p><p><b>  2.設(shè)計(jì)說(shuō)明</b></p><p><b>  2

13、.1界面設(shè)計(jì)</b></p><p>  迷宮系統(tǒng)歡迎界面如圖2.1所示。</p><p>  由三個(gè)菜單組成,為創(chuàng)建地圖、打印路徑與退出。</p><p>  圖2.1 迷宮系統(tǒng)歡迎界面</p><p>  迷宮界面如圖2.2所示。</p><p>  先按1創(chuàng)建地圖,再輸入迷宮行與列,再輸入迷宮布局,

14、出現(xiàn)圖2.2的內(nèi)容。</p><p>  圖2.2 迷宮游戲界面</p><p>  路徑界面如圖2.3所示。</p><p>  創(chuàng)建好地圖之后,按2就可以打印路徑。</p><p><b>  圖2.3 路徑界面</b></p><p><b>  2.2數(shù)據(jù)結(jié)構(gòu)</b>

15、</p><p>  數(shù)據(jù)結(jié)構(gòu)圖如 圖2.4所示。</p><p>  主函數(shù)調(diào)用迷宮函數(shù),迷宮函數(shù)調(diào)用輸出路徑函數(shù),從而實(shí)現(xiàn)功能。</p><p>  圖2.4 數(shù)據(jù)結(jié)構(gòu)圖</p><p><b>  3.實(shí)現(xiàn)與測(cè)試</b></p><p>  優(yōu)良。整個(gè)測(cè)試包含如下內(nèi)容:</p>

16、<p><b>  綜合評(píng)估:</b></p><p>  整個(gè)軟件開(kāi)發(fā)難度還算較簡(jiǎn)單,過(guò)程雖然繁瑣,容易出錯(cuò),但總的結(jié)果還算可以。</p><p>  整體上較好,樣式簡(jiǎn)單,美觀。</p><p>  b. 軟件開(kāi)發(fā)中計(jì)劃的執(zhí)行情況:</p><p>  測(cè)試頁(yè)面的連接情況及是否出現(xiàn)異常狀況。</p

17、><p>  測(cè)試結(jié)果狀況良好,無(wú)出現(xiàn)不良情況。</p><p>  c. 軟件質(zhì)量目標(biāo)完成情況: </p><p>  完成情況良好,質(zhì)量品質(zhì)</p><p><b>  3.1結(jié)果</b></p><p>  輸入一些臨界數(shù)據(jù)進(jìn)行測(cè)試:</p><p>  當(dāng)輸入的迷宮為4

18、*4的</p><p><b>  1 1 1 1</b></p><p><b>  1 1 1 1</b></p><p><b>  1 1 1 1</b></p><p><b>  1 1 1 1</b></p><p>

19、  時(shí),輸出結(jié)果為“不存在路徑”。如下圖3.1:</p><p>  圖3.1 </p><p>  當(dāng)輸入的迷宮為4*4的</p><p><b>  0 0 0 0</b></p><p><b>  0 0 0 0</b></p><p><b>

20、;  0 0 0 0 </b></p><p><b>  0 0 0 0</b></p><p>  時(shí),輸出結(jié)果如下圖3.2</p><p><b>  圖3.2 </b></p><p><b>  3.2測(cè)試過(guò)程</b></p><p&g

21、t;  頁(yè)面測(cè)試報(bào)告如表3.1:</p><p>  表3.1 頁(yè)面測(cè)試報(bào)告</p><p>  迷宮結(jié)果測(cè)試報(bào)告如表3.2:</p><p>  表3.2 迷宮輸出報(bào)告</p><p><b>  總結(jié)</b></p><p><b>  綜合評(píng)估:</b></p&g

22、t;<p>  整個(gè)軟件開(kāi)發(fā)難度還算較簡(jiǎn)單,過(guò)程雖然繁瑣,容易出錯(cuò),但總的結(jié)果還算可以。</p><p>  整體上較好,樣式簡(jiǎn)單,美觀。</p><p>  軟件開(kāi)發(fā)中計(jì)劃的執(zhí)行情況</p><p>  測(cè)試頁(yè)面的連接情況及是否出現(xiàn)異常狀況。</p><p>  測(cè)試結(jié)果狀況良好,無(wú)出現(xiàn)不良情況。</p><

23、;p>  軟件質(zhì)量目標(biāo)完成情況: </p><p>  完成情況良好,質(zhì)量品質(zhì)優(yōu)良。</p><p>  總結(jié)開(kāi)發(fā)活動(dòng)中的檢驗(yàn)與教訓(xùn)</p><p>  在本次課程設(shè)計(jì)中,我學(xué)會(huì)了許多的東西,開(kāi)始的時(shí)候,我犯了許多的錯(cuò)誤,通過(guò)同學(xué)和老師的幫助,一個(gè)個(gè)突破,才有這次的課程設(shè)計(jì)。所以。做啥事都得認(rèn)真對(duì)待,這樣才能提升自己。</p><p>

24、<b>  參考文獻(xiàn)</b></p><p>  [1] 王挺. 數(shù)據(jù)結(jié)構(gòu)[M]. 北京:清華大學(xué)出版社,2005.</p><p>  [2] 吳偉民. 數(shù)據(jù)結(jié)構(gòu)[M]. 北京:清華大學(xué)出版社,2006. </p><p><b>  附錄A 源代碼</b></p><p>  #include&

25、lt;iostream></p><p>  using namespace std;</p><p>  struct D </p><p><b>  {</b></p><p>  int x; //x代表當(dāng)前位置的行坐標(biāo)</p><p>  int y;

26、 //y代表當(dāng)前位置的列坐標(biāo)</p><p>  int dir; </p><p><b>  };</b></p><p>  struct Link </p><p><b>  {</b></p><p><b> 

27、 D data;</b></p><p>  Link *next;</p><p><b>  };</b></p><p><b>  //Stack</b></p><p>  class Stack</p><p><b>  {</b&g

28、t;</p><p><b>  private:</b></p><p>  Link *top; //指向棧頂節(jié)點(diǎn)的指針</p><p><b>  public:</b></p><p>  Stack(); </p><p>

29、;  ~Stack(); </p><p>  void Push(const D& e); //把元素data壓入棧中</p><p>  D Pop(); //使棧頂元素出棧</p><p>  D GetTop(); //取出棧頂元素

30、 </p><p>  bool Empty(); //判斷棧是否為空,是空的話返回true</p><p><b>  };</b></p><p>  Stack::Stack() //構(gòu)造函數(shù),置空棧</p><p><b>  {</b></p>

31、;<p><b>  top=NULL;</b></p><p><b>  }</b></p><p>  Stack::~Stack() {} //析構(gòu)函數(shù)</p><p>  void Stack::Push(const D & e) //把元素x壓入棧中<

32、/p><p><b>  {</b></p><p>  Link *P=new Link;</p><p>  P->data=e;</p><p>  P->next=top;</p><p><b>  top=P;</b></p><p&g

33、t;<b>  }</b></p><p>  D Stack::Pop() //使棧頂元素出棧</p><p><b>  { </b></p><p>  Link *P=top;</p><p>  top=top->next;</p>&l

34、t;p>  D Temp=P->data;</p><p><b>  delete P;</b></p><p>  return Temp;</p><p><b>  }</b></p><p>  D Stack::GetTop() {return top->data;}

35、 //取出棧頂元素</p><p>  bool Stack::Empty() { return (top==NULL);}</p><p>  int move[8][2]={ {0,1},{1,1},{1,0},{1,-1},{0,-1},{-1,-1},{-1,0},{-1,1} }; //定義當(dāng)前位置移動(dòng)的8個(gè)方向</p><p&

36、gt;  bool FindPath(int **maze,const int& m,const int & n); //尋找路徑</p><p>  void Print(Stack & p,int ** maze,const int & m,const int & n); //輸出迷宮的路徑</p><p>  int** Cr

37、eateMaze(int &m,int &n); //創(chuàng)建迷宮</p><p>  //返回存取迷宮的二維指針</p><p>  int main()</p><p><b>  {</b></p><p>  int m=0,n=0; //定義迷宮的長(zhǎng)和寬</p>

38、<p>  int **maze; //定義二維指針存取迷宮</p><p>  int choice=1,create=0;</p><p>  while(choice)</p><p><b>  {</b></p><p>  cout<<"************

39、*******迷宮系統(tǒng)*************************"<<endl;</p><p>  cout<<" 請(qǐng)選擇"<<endl;</p><p>  cout<<"創(chuàng)建迷宮地圖-----------------------------------

40、---①"<<endl;</p><p>  cout<<"打印路徑 --------------------------------------②"<<endl;</p><p>  cout<<"退出 --------------------------------------○

41、"<<endl;</p><p>  cout<<"****************************************************"<<endl;</p><p>  cin>>choice;</p><p>  switch(choice)</p>

42、<p><b>  {</b></p><p><b>  case 1: </b></p><p>  maze=CreateMaze(m,n); //調(diào)用GetMaze(int &m,int &n)函數(shù),得到迷宮</p><p><b>  create=1;</b>

43、</p><p><b>  break;</b></p><p><b>  case 2:</b></p><p>  if(0==create)</p><p><b>  {</b></p><p>  cout<<"未創(chuàng)建

44、迷宮地圖,請(qǐng)先創(chuàng)建地圖!!"<<endl;</p><p>  maze=CreateMaze(m,n); </p><p><b>  }</b></p><p>  if(FindPath(maze,m,n)) //調(diào)用Mazepath(int **maze,int m,int n)函數(shù)獲取路徑</p>

45、<p>  cout<<"迷宮路徑探索成功!\n";</p><p><b>  else </b></p><p>  cout<<"路徑不存在!\n";</p><p><b>  break;</b></p><p>&

46、lt;b>  case 0:</b></p><p><b>  break;</b></p><p><b>  default:</b></p><p>  cout<<"輸入有誤,請(qǐng)重新輸入"<<endl;</p><p><

47、b>  break;</b></p><p><b>  }</b></p><p><b>  } </b></p><p><b>  return 0;</b></p><p><b>  }</b></p><

48、p>  int** CreateMaze(int &m,int &n)//返回存取迷宮的二維指針</p><p><b>  {</b></p><p>  int **maze; //定義二維指針存取迷宮</p><p>  int i=0,j=0,a,b;</p><p&g

49、t;  cout<<"請(qǐng)輸入迷宮的長(zhǎng)和寬:";</p><p>  cin>>a>>b; //輸入迷宮的長(zhǎng)和寬</p><p>  if(a<=1||b<=1)</p><p><b>  {</b></p><p>  cout<<&

50、quot;設(shè)置有誤,默認(rèn)設(shè)為2X2大小的"<<endl;</p><p><b>  a=2;</b></p><p><b>  b=2;</b></p><p><b>  }</b></p><p>  cout<<"請(qǐng)輸入迷宮

51、內(nèi)容:(0代表可通,1代表不可通)\n";</p><p><b>  m=a;</b></p><p>  n=b; //m,n分別代表迷宮的行數(shù)和列數(shù)</p><p>  maze=new int *[m+2]; </p><p>  for(i= 0;i<m+2;++i) &l

52、t;/p><p><b>  {</b></p><p>  maze[i]=new int[n+2];</p><p><b>  }</b></p><p>  for(i=1;i<=m;++i) </p><p>  for(j=1;j<=n;

53、++j)</p><p>  cin>>maze[i][j];</p><p>  for(i=0;i<m+2;++i)</p><p>  maze[i][0]=maze[i][n+1]=1;</p><p>  for(i=0;i<n+2;++i)</p><p>  maze[0][i]=

54、maze[m+1][i]=1;</p><p><b>  //設(shè)置邊界</b></p><p>  return maze; //返回存貯迷宮的二維指針maze</p><p><b>  };</b></p><p>  bool FindPath(int **maze

55、,const int& m,const int & n)//尋找迷宮maze中從(0,0)到(m,n)的路徑</p><p>  //到則返回true,否則返回false</p><p><b>  {</b></p><p>  Stack Spath,Sproc; //定義棧Sproc、Spath,分別存

56、 探索迷宮的過(guò)程 和 存儲(chǔ)路徑</p><p>  D Temp1,Temp2; </p><p>  int x,y,loop;</p><p>  Temp1.x=1;</p><p>  Temp1.y=1;</p><p>  Sproc.Push(Temp1); /

57、/將入口位置入棧</p><p>  Spath.Push(Temp1);</p><p>  maze[1][1]=2; //標(biāo)志入口位置已到達(dá)過(guò)</p><p>  while(!Sproc.Empty()) //棧Sproc非空,則反復(fù)探索</p><p><b>  {</b></p>

58、<p>  Temp2=Sproc.GetTop(); //獲取棧頂元素</p><p>  if(!(Sproc.GetTop().x==Spath.GetTop().x&&Sproc.GetTop().y==Spath.GetTop().y)) </p><p>  Spath.Push(Temp2); //如果有新位置入棧,則把上一個(gè)探索的位置

59、存入棧Spath</p><p>  for(loop=0;loop<8;++loop) //探索當(dāng)前位置的8個(gè)相鄰位置</p><p><b>  {</b></p><p>  x=Temp2.x+move[loop][0]; //計(jì)算出新位置x位置值</p><p>  y=Temp2.y+mov

60、e[loop][1]; //計(jì)算出新位置y位置值</p><p>  if(maze[x][y]==0) //判斷新位置是否可達(dá)</p><p><b>  {</b></p><p>  Temp1.x=x;</p><p>  Temp1.y=y;</p><p> 

61、 maze[x][y]=2; //標(biāo)志新位置已到達(dá)過(guò)</p><p>  Sproc.Push(Temp1); //新位置入棧</p><p><b>  }</b></p><p>  if((x==(m))&&(y==(n))) //成功到達(dá)出口</p><p>

62、;<b>  {</b></p><p>  Temp1.x=m;</p><p>  Temp1.y=n;</p><p>  Temp1.dir=0;</p><p>  Spath.Push(Temp1); //把最后一個(gè)位置入棧</p><p>  Print(Spath,ma

63、ze,m,n); //輸出路徑</p><p>  return true; //表示成功找到路徑</p><p><b>  }</b></p><p><b>  }//for</b></p><p>  //如果沒(méi)有新位置入棧,則返回到上一個(gè)位置&l

64、t;/p><p>  if(Sproc.GetTop().x==Spath.GetTop().x&&Sproc.GetTop().y==Spath.GetTop().y)</p><p><b>  {</b></p><p>  Sproc.Pop();</p><p>  Spath.Pop();<

65、;/p><p><b>  }</b></p><p><b>  }//while</b></p><p>  return false; //表示查找失敗,即迷宮無(wú)路經(jīng)</p><p><b>  }</b></p><p>  vo

66、id Print(Stack & p,int ** maze,const int & m,const int & n) //輸出路徑</p><p><b>  {</b></p><p>  Stack temp=p;</p><p><b>  D data;</b></p&

67、gt;<p>  while(!temp.Empty())</p><p><b>  {</b></p><p>  data=temp.Pop();</p><p>  maze[data.x][data.y]=8;</p><p><b>  }</b></p>&

68、lt;p><b>  int i,j;</b></p><p>  for(i=1;i<=m;++i)</p><p>  for(j=1;j<=n;++j)</p><p><b>  {</b></p><p>  if(maze[i][j]==8)</p>&l

69、t;p>  cout<<'*';</p><p><b>  else</b></p><p>  cout<<maze[i][j];</p><p>  cout<<' ';</p><p><b>  if(j==n)</b&g

溫馨提示

  • 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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(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)論