數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-迷宮問(wèn)題_第1頁(yè)
已閱讀1頁(yè),還剩16頁(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>  目錄</b></p><p>  第一部分 需求分析</p><p>  第二部分 詳細(xì)設(shè)計(jì)</p><p>  第三部分 調(diào)試分析</p><p>  第四部分 用戶手冊(cè)</p><p>  第五部分 測(cè)試結(jié)果<

2、;/p><p>  第六部分 附錄</p><p>  第七部分 參考文獻(xiàn)</p><p><b>  需求分析</b></p><p>  1、對(duì)于給定的一個(gè)迷宮,給出一個(gè)出口和入口,找一條從入口到出口的通路,并把這條通路顯示出來(lái);如果沒(méi)有找到這樣的通路給出沒(méi)有這樣通路的信息。</p>&

3、lt;p>  2、可以用一個(gè)m×n的長(zhǎng)方陣表示迷宮,0和1分別表示迷宮中的通路和障礙。設(shè)計(jì)一個(gè)程序,對(duì)任意設(shè)定的迷宮,求出一條從入口到出口的通路,或得出沒(méi)有通路的結(jié)論。</p><p>  3、編寫(xiě)一個(gè)求解迷宮的非遞歸程序。求得的通路以三元組(i,j,d)的形式輸出,其中:(i,j)指示迷宮中的一個(gè)坐標(biāo),d表示走到下一坐標(biāo)的方向。</p><p>  4、由于迷宮是任意給定

4、的,所以程序要能夠?qū)o定的迷宮生成對(duì)應(yīng)的矩陣表示,所以程序的輸入包括了矩陣的行數(shù)、列數(shù)、迷宮內(nèi)墻的個(gè)數(shù)、迷宮內(nèi)墻的坐標(biāo)、所求的通路的入口坐標(biāo)、出口坐標(biāo)。</p><p><b>  二、詳細(xì)設(shè)計(jì)</b></p><p>  1、計(jì)算機(jī)解迷宮通常用的是“窮舉求解“方法,即從人口出發(fā),順著某一個(gè)方向進(jìn)行探索,若能走通,則繼續(xù)往前進(jìn);否則沿著原路退回,換一個(gè)方向繼續(xù)探索,直

5、至出口位置,求得一條通路。假如所有可能的通路都探索到而未能到達(dá)出口,則所設(shè)定的迷宮沒(méi)有通路。</p><p>  可以二維數(shù)組存儲(chǔ)迷宮數(shù)據(jù),通常設(shè)定入口點(diǎn)的下標(biāo)為(1,1),出口點(diǎn)的下標(biāo)為(n,n)。為處理方便起見(jiàn),可在迷宮的四周加一圈障礙。對(duì)于迷宮中任一位置,均可約定有東、南、西、北四個(gè)方向可通。</p><p>  2、如果在某個(gè)位置上四個(gè)方向都走不通的話,就退回到前一個(gè)位置,換一個(gè)方

6、向再試,如果這個(gè)位置已經(jīng)沒(méi)有方向可試了就再退一步,如果所有已經(jīng)走過(guò)的位置的四個(gè)方向都試探過(guò)了,一直退到起始點(diǎn)都沒(méi)有走通,那就說(shuō)明這個(gè)迷宮根本不通。</p><p>  3、所謂"走不通"不單是指遇到"墻擋路",還有"已經(jīng)走過(guò)的路不能重復(fù)走第二次",它包括"曾經(jīng)走過(guò)而沒(méi)有走通的路"。  顯然為了保證在任何位置上都能沿原路退回,需要用一

7、個(gè)"后進(jìn)先出"的結(jié)構(gòu)即棧來(lái)保存從入口到當(dāng)前位置的路徑。并且在走出出口之后,棧中保存的正是一條從入口到出口的路徑。</p><p>  4、若當(dāng)前位置“可通”,則納入“當(dāng)前路徑”,并繼續(xù)朝“下一位置”探索;若當(dāng)前位置“不可通”,則應(yīng)順著“來(lái)的方向”退回到“前一通道塊”,然后朝著除“來(lái)向”之外的其他方向繼續(xù)探索;若該通道塊的四周四個(gè)方塊均“不可通”,則應(yīng)從“當(dāng)前路徑”上刪除該通道塊。</p&

8、gt;<p>  所謂“下一位置”指的是“當(dāng)前位置”四周四個(gè)方向(東、南、西、北)上相鄰的方塊。假設(shè)以棧S記錄“當(dāng)前路徑”,則棧頂中存放的是“當(dāng)前路徑上最后一個(gè)通道塊”。由此,“納入路徑”的操作即為“當(dāng)前位置入?!保弧皬漠?dāng)前路徑上刪除前一通道塊”的操作即為“出?!薄?lt;/p><p>  5、找通路的程序的關(guān)鍵部分可以表示如下:</p><p>  do{ 若當(dāng)前位置可通,

9、 則{  將當(dāng)前位置插入棧頂;       // 納入路徑   若該位置是出口位置,則算法結(jié)束;   // 此時(shí)棧中存放的是一條從入口位置到出口位置的路徑  否則切換當(dāng)前位置的東鄰方塊為新的當(dāng)前位置; }</p><p><b>  否則</b></p><p>  {  若棧不空且棧頂位置尚有其他方向未被探索,  則設(shè)定新的當(dāng)前位置為: 沿順

10、時(shí)針?lè)较蛐D(zhuǎn)找到的棧頂位置的下一相鄰塊;  若棧不空但棧頂位置的四周均不可通,   則{ 刪去棧頂位置;     // 從路徑中刪去該通道塊   若棧不空,則重新測(cè)試新的棧頂位置,   直至找到一個(gè)可通的相鄰塊或出棧至棧空;   } </p><p><b>  } </b></p><p>  } while (棧不空);</p>&

11、lt;p>  6、程序中用的數(shù)據(jù)結(jié)構(gòu)解析:</p><p> ?、?程序中用了順序棧保存當(dāng)前找到的路徑,當(dāng)前位置不可通時(shí),可以出棧,退回到前一個(gè)位置再繼續(xù)探索通路,棧的定義如下:</p><p>  struct SqStack</p><p><b>  {</b></p><p>  SElemType *ba

12、se; // 在棧構(gòu)造之前和銷毀之后,base的值為NULL</p><p>  SElemType *top; // 棧頂指針</p><p>  int stacksize; // 當(dāng)前已分配的存儲(chǔ)空間,以元素為單位</p><p><b>  }; // 順序棧</b></p><p> ?、?棧中元素的類型結(jié)構(gòu)&

13、lt;/p><p>  程序中先定義了一個(gè)表示坐標(biāo)的類型結(jié)構(gòu):</p><p>  struct PosType // 迷宮坐標(biāo)位置類型</p><p><b>  {</b></p><p>  int x; // 行值</p><p>  int y; // 列值</p><p

14、><b>  };</b></p><p>  棧中元素的類型結(jié)構(gòu)如下:</p><p>  struct SElemType // 棧的元素類型</p><p><b>  {</b></p><p>  int ord; // 通道塊在路徑上的"序號(hào)"</p><p&g

15、t;  PosType seat; // 通道塊在迷宮中的"坐標(biāo)位置"</p><p>  int di; // 從此通道塊走向下一通道塊的"方向"(0~3表示東~北)</p><p><b>  };</b></p><p><b>  7、主函數(shù)的流程圖</b></p><p><b>

16、;  調(diào)試分析</b></p><p>  1、對(duì)于程序的設(shè)計(jì)由簡(jiǎn)單到復(fù)雜,先設(shè)計(jì)一個(gè)整體的輪廓然后再慢慢的增加程序的功能,這樣能夠有效的減少錯(cuò)誤,功能慢慢的增加,在前一步的程序運(yùn)行通過(guò)之后再繼續(xù)增加功能,這樣在檢查錯(cuò)誤的時(shí)候比較有目的性,提高寫(xiě)程序的效率。</p><p>  2、對(duì)于程序中的錯(cuò)誤,如果遇到說(shuō)變量沒(méi)有定義或者數(shù)據(jù)結(jié)構(gòu)沒(méi)定義的錯(cuò)誤,可能是由于你在定義這種數(shù)據(jù)結(jié)構(gòu)

17、的變量時(shí)數(shù)據(jù)結(jié)構(gòu)還沒(méi)有定義,也就是說(shuō)在定義此數(shù)據(jù)結(jié)構(gòu)的變量的語(yǔ)句要放在聲明這種結(jié)構(gòu)體之后。</p><p>  3、在寫(xiě)程序時(shí)要注意printf和scanf語(yǔ)句的格式,格式不對(duì)會(huì)得不到你想要的結(jié)果。</p><p>  4、寫(xiě)程序時(shí)一定要瞻前顧后,前后一致,包括名稱、數(shù)據(jù)類型等等。</p><p><b>  四、用戶手冊(cè)</b></p&

18、gt;<p>  在使用程序時(shí)嚴(yán)格按照程序給出的提示一步一步來(lái),下面給出程序正常執(zhí)行的步驟:</p><p>  1、程序會(huì)提示“請(qǐng)輸入迷宮的行數(shù),列數(shù)(包括外墻):”,這時(shí)就需要輸入表示迷宮的二維數(shù)組的行數(shù)和列數(shù),需要注意的是由于我們?cè)诿詫m周圍加了一道墻,所以要輸入的行列數(shù)要比實(shí)際表示迷宮的行列數(shù)多兩行兩列。</p><p>  2、程序提示“請(qǐng)輸入迷宮內(nèi)墻單元數(shù):”,此時(shí)

19、需要輸入迷宮中墻的數(shù)目。</p><p>  3、程序提示“請(qǐng)依次輸入迷宮內(nèi)墻每個(gè)單元的行數(shù),列數(shù):”,此時(shí)要輸入迷宮中所有墻的坐標(biāo),我們用數(shù)組中的一個(gè)元素來(lái)表示墻。</p><p>  4、在輸入了迷宮所有內(nèi)墻的坐標(biāo)后,程序會(huì)顯示出迷宮的結(jié)構(gòu),然后程序會(huì)提示“請(qǐng)輸入起點(diǎn)的行數(shù),列數(shù):”,此時(shí)需要輸入所求通路的起點(diǎn)坐標(biāo)。</p><p>  5、程序提示“請(qǐng)輸入終點(diǎn)

20、的行數(shù),列數(shù):”,此時(shí)需要輸入所求通路的終點(diǎn)的坐標(biāo)。</p><p>  6、終點(diǎn)坐標(biāo)輸入完畢之后,程序會(huì)顯示出兩種運(yùn)行的結(jié)果,一種是輸出了迷宮的結(jié)構(gòu),此時(shí)迷宮中已包含了所找的通路,用連續(xù)的數(shù)字表示出了通路在迷宮中是如何走的,此時(shí)迷宮中的-1表示找通路時(shí)走過(guò)的單元但是通路不通。</p><p>  注意:再輸入內(nèi)墻單元的坐標(biāo)是一定要細(xì)心,不要錯(cuò)輸,也不要漏輸。否則程序會(huì)出錯(cuò)。</p&

21、gt;<p><b>  五、測(cè)試結(jié)果</b></p><p>  迷宮的測(cè)試數(shù)據(jù)如下:左上角(1,1)為入口,右下角(9,8)為出口。</p><p>  1 2 3 4 5 6 7 8</p><p><b>  程序的測(cè)試結(jié)果為:</b></p>

22、<p><b>  1、程序的開(kāi)始界面</b></p><p>  2、輸入迷宮的行數(shù)列數(shù)之后</p><p>  3、輸入內(nèi)墻的個(gè)數(shù)之后</p><p>  4、再輸入了所有內(nèi)墻的坐標(biāo)后,程序會(huì)給出迷宮的結(jié)構(gòu)</p><p>  5、輸入所求通路的起點(diǎn)坐標(biāo)</p><p>  6、輸入

23、所求通路的終點(diǎn)坐標(biāo)后會(huì)得到結(jié)果</p><p> ?、?結(jié)果以迷宮的形式輸出</p><p>  ② 結(jié)果用坐標(biāo)和下一位值的方向表示</p><p>  六、附錄(附有完整的源程序)</p><p><b>  源程序如下:</b></p><p>  #include"stdio.h&

24、quot;</p><p>  #include"stdlib.h"</p><p>  #define TRUE 1</p><p>  #define FALSE 0</p><p>  #define OK 1</p><p>  #define ERROR 0</p><

25、p>  #define OVERFLOW -2</p><p>  typedef int Status;</p><p>  #define STACK_INIT_SIZE 10 // 存儲(chǔ)空間初始分配量</p><p>  #define STACKINCREMENT 2 // 存儲(chǔ)空間分配增量</p><p>  struct P

26、osType // 迷宮坐標(biāo)位置類型</p><p><b>  {</b></p><p>  int x; // 行值</p><p>  int y; // 列值</p><p><b>  };</b></p><p>  struct SElemType // 棧的

27、元素類型</p><p><b>  {</b></p><p>  int ord; // 通道塊在路徑上的"序號(hào)"</p><p>  PosType seat; // 通道塊在迷宮中的"坐標(biāo)位置"</p><p>  int di; // 從此通道塊走向下一通道塊的"方向"(0~3表示東~北)</p>

28、<p><b>  };</b></p><p>  struct SqStack</p><p><b>  {</b></p><p>  SElemType *base; // 在棧構(gòu)造之前和銷毀之后,base的值為NULL</p><p>  SElemType *top; //

29、 棧頂指針</p><p>  int stacksize; // 當(dāng)前已分配的存儲(chǔ)空間,以元素為單位</p><p><b>  }; // 順序棧</b></p><p>  SqStack S;</p><p>  #define MAXLENGTH 25 // 設(shè)迷宮的最大行列為25</p><

30、;p>  typedef int MazeType[MAXLENGTH][MAXLENGTH]; // 迷宮數(shù)組[行][列]</p><p><b>  // 全局變量</b></p><p>  MazeType m; // 迷宮數(shù)組</p><p>  int curstep=1; // 當(dāng)前足跡,初值為1</p>&l

31、t;p>  Status InitStack(SqStack &S)</p><p>  { // 構(gòu)造一個(gè)空棧S</p><p>  if(!(S.base=(SElemType *)malloc(STACK_INIT_SIZE*sizeof(SElemType))))</p><p>  exit(OVERFLOW); // 存儲(chǔ)分配失敗</

32、p><p>  S.top=S.base;</p><p>  S.stacksize=STACK_INIT_SIZE;</p><p>  return OK;</p><p><b>  }</b></p><p>  Status StackEmpty(SqStack S)</p>

33、<p>  { // 若棧S為空棧,則返回TRUE,否則返回FALSE</p><p>  if(S.top==S.base)</p><p>  return TRUE;</p><p><b>  else</b></p><p>  return FALSE;</p><p>&

34、lt;b>  }</b></p><p>  Status Push(SqStack &S,SElemType e)</p><p>  { // 插入元素e為新的棧頂元素</p><p>  if(S.top-S.base>=S.stacksize) // 棧滿,追加存儲(chǔ)空間</p><p><b>

35、;  {</b></p><p>  S.base=(SElemType*) realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(SElemType));</p><p>  if(!S.base)</p><p>  exit(OVERFLOW); // 存儲(chǔ)分配失敗</p><p&

36、gt;  S.top=S.base+S.stacksize;</p><p>  S.stacksize+=STACKINCREMENT;</p><p><b>  }</b></p><p>  *(S.top)++=e;</p><p>  return OK;</p><p><b&

37、gt;  }</b></p><p>  Status Pop(SqStack &S,SElemType &e)</p><p>  { // 若棧不空,則刪除S的棧頂元素,用e返回其值,并返回OK;否則返回ERROR</p><p>  if(S.top==S.base)</p><p>  return ERR

38、OR;</p><p>  e=*--S.top;</p><p>  return OK;</p><p><b>  }</b></p><p>  Status Pass(PosType b)</p><p>  { // 當(dāng)迷宮m的b點(diǎn)的序號(hào)為0(可通過(guò)路徑),return OK; 否則,

39、return ERROR。</p><p>  if(m[b.x][b.y]==0)</p><p>  return OK;</p><p><b>  else</b></p><p>  return ERROR;</p><p><b>  }</b></p&g

40、t;<p>  void FootPrint(PosType a)</p><p>  { // 使迷宮m的a點(diǎn)的序號(hào)變?yōu)樽阚E(curstep)</p><p>  m[a.x][a.y]=curstep;</p><p><b>  }</b></p><p>  PosType NextPos(PosT

41、ype c,int di)</p><p>  { // 根據(jù)當(dāng)前位置及移動(dòng)方向,返回下一位置</p><p>  PosType direc[4]={{0,1},{1,0},{0,-1},{-1,0}}; // {行增量,列增量}</p><p>  // 移動(dòng)方向,依次為東南西北</p><p>  c.x+=direc[di].x;&l

42、t;/p><p>  c.y+=direc[di].y;</p><p><b>  return c;</b></p><p><b>  }</b></p><p>  void MarkPrint(PosType b)</p><p>  { // 使迷宮m的b點(diǎn)的序號(hào)變?yōu)?/p>

43、-1(不能通過(guò)的路徑)</p><p>  m[b.x][b.y]=-1;</p><p><b>  }</b></p><p>  Status MazePath(PosType start,PosType end) // 算法3.3</p><p>  { // 若迷宮maze中存在從入口start到出口end的通

44、道,則求得一條</p><p>  // 存放在棧中(從棧底到棧頂),并返回TRUE;否則返回FALSE</p><p>  PosType curpos;</p><p>  InitStack(S);</p><p>  SElemType e;</p><p>  curpos=start;</p>

45、<p><b>  do</b></p><p><b>  {</b></p><p>  if(Pass(curpos))</p><p>  { // 當(dāng)前位置可以通過(guò),即是未曾走到過(guò)的通道塊</p><p>  FootPrint(curpos); // 留下足跡</p&g

46、t;<p>  e.ord=curstep;</p><p>  e.seat.x=curpos.x;</p><p>  e.seat.y=curpos.y;</p><p><b>  e.di=0;</b></p><p>  Push(S,e); // 入棧當(dāng)前位置及狀態(tài)</p>&l

47、t;p>  curstep++; // 足跡加1</p><p>  if(curpos.x==end.x&&curpos.y==end.y) // 到達(dá)終點(diǎn)(出口)</p><p>  return TRUE;</p><p>  curpos=NextPos(curpos,e.di);</p><p><b&g

48、t;  }</b></p><p><b>  else</b></p><p>  { // 當(dāng)前位置不能通過(guò)</p><p>  if(!StackEmpty(S))</p><p><b>  {</b></p><p>  Pop(S,e); // 退棧到

49、前一位置</p><p>  curstep--;</p><p>  while(e.di==3&&!StackEmpty(S)) // 前一位置處于最后一個(gè)方向(北)</p><p><b>  {</b></p><p>  MarkPrint(e.seat); // 留下不能通過(guò)的標(biāo)記(-1)&l

50、t;/p><p>  Pop(S,e); // 退回一步</p><p>  curstep--;</p><p><b>  }</b></p><p>  if(e.di<3) // 沒(méi)到最后一個(gè)方向(北)</p><p><b>  {</b></p>

51、<p>  e.di++; // 換下一個(gè)方向探索</p><p>  Push(S,e);</p><p>  curstep++;</p><p>  curpos=NextPos(e.seat,e.di); // 設(shè)定當(dāng)前位置是該新方向上的相鄰塊</p><p><b>  }</b></p>

52、<p><b>  }</b></p><p><b>  }</b></p><p>  }while(!StackEmpty(S));</p><p>  return FALSE;</p><p><b>  }</b></p><p&g

53、t;  void Print(int x,int y)</p><p>  { // 輸出迷宮的解</p><p><b>  int i,j;</b></p><p>  for(i=0;i<x;i++)</p><p><b>  {</b></p><p>  f

54、or(j=0;j<y;j++)</p><p>  printf("%3d",m[i][j]);</p><p>  printf("\n");</p><p><b>  }</b></p><p><b>  }</b></p><

55、;p>  void main()</p><p><b>  {</b></p><p>  PosType begin,end;</p><p>  int i,j,x,y,x1,y1;</p><p>  SElemType a;</p><p>  SqStack T;</p&g

56、t;<p>  InitStack(T);</p><p>  printf("請(qǐng)輸入迷宮的行數(shù),列數(shù)(包括外墻):");</p><p>  scanf("%d%d",&x,&y);</p><p>  for(i=0;i<y;i++) // 定義周邊值為0(同墻)</p>

57、<p><b>  {</b></p><p>  m[0][i]=1; // 行周邊</p><p>  m[x-1][i]=1;</p><p><b>  }</b></p><p>  for(j=1;j<x-1;j++)</p><p><b&

58、gt;  {</b></p><p>  m[j][0]=1; // 列周邊</p><p>  m[j][y-1]=1;</p><p><b>  }</b></p><p>  for(i=1;i<x-1;i++)</p><p>  for(j=1;j<y-1;j+

59、+)</p><p>  m[i][j]=0; // 定義通道初值為0</p><p>  printf("請(qǐng)輸入迷宮內(nèi)墻單元數(shù):");</p><p>  scanf("%d",&j);</p><p>  printf("請(qǐng)依次輸入迷宮內(nèi)墻每個(gè)單元的行數(shù),列數(shù):\n");

60、</p><p>  for(i=1;i<=j;i++)</p><p><b>  {</b></p><p>  scanf("%d%d",&x1,&y1);</p><p>  m[x1][y1]=1; // 定義墻的值為1</p><p><

61、b>  }</b></p><p>  printf("迷宮結(jié)構(gòu)如下:\n");</p><p>  Print(x,y);</p><p>  printf("請(qǐng)輸入起點(diǎn)的行數(shù),列數(shù):");</p><p>  scanf("%d%d",&begin.x,

62、&begin.y);</p><p>  printf("請(qǐng)輸入終點(diǎn)的行數(shù),列數(shù):");</p><p>  scanf("%d%d",&end.x,&end.y);</p><p>  if(MazePath(begin,end)) // 求得一條通路</p><p><

63、b>  {</b></p><p>  printf("此迷宮從入口到出口的一條路徑如下:\n");</p><p>  Print(x,y); // 輸出此通路</p><p>  while(!StackEmpty(S))</p><p><b>  {</b></p>

64、;<p><b>  Pop(S,a);</b></p><p>  Push(T,a);</p><p><b>  }</b></p><p>  printf("找到的路徑用坐標(biāo)表示如下:\n");</p><p>  while(!StackEmpty(T)

65、)</p><p><b>  {</b></p><p><b>  Pop(T,a);</b></p><p>  printf("%d%3d%3d\n",a.seat.x,a.seat.y,a.di);</p><p><b>  }</b></

66、p><p><b>  }</b></p><p><b>  else</b></p><p>  printf("此迷宮沒(méi)有從入口到出口的路徑\n");</p><p><b>  }</b></p><p><b>  七

溫馨提示

  • 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)論