版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p> 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計</p><p><b> 報告</b></p><p> 學(xué) 院:_電氣與信息工程學(xué)院_ 專業(yè)班級: </p><p> 學(xué)生姓名: 學(xué) 號: </p><p> 設(shè)計地點(單位)__ _ 計算機基礎(chǔ)自主學(xué)習(xí)中心 __ _ _設(shè)計題
2、目:_ 停車場管理模擬程序的設(shè)計_______ </p><p> 完成日期:2012年 7 月 6 日 </p><p> 指導(dǎo)教師評語: ______________________ _________________</p><p> ____________________________________________
3、_____________________________________________________________________________________________________________________________________________________________ __________ _ </p><p
4、> 成績(五級記分制):______ __________ 指導(dǎo)教師(簽字):________ ________</p><p><b> 課程設(shè)計任務(wù)書</b></p><p> 設(shè)計題目:停車場管理模擬程序的設(shè)計</p><p><b> 摘要</b></p>
5、;<p> 在這個科技發(fā)達的時代,汽車對于我們來說越來越普遍,而人們對停車場的管理也更加信息化。本系統(tǒng)主要是對僅有一個門的停車場的簡單管理的設(shè)計。對汽車進入停車場,若停車場滿,進入便道等候,車場中有車離開后,便道上的車依次進入停車場有一定的管理。而且停車場也有合理的收費標(biāo)準(zhǔn)。</p><p> 該系統(tǒng)主要運用的是C語言和數(shù)據(jù)結(jié)構(gòu)的相關(guān)知識,用棧(后進先出)來模擬停車場,隊列(先進先出)來模擬便道
6、實現(xiàn)對汽車進入和離開的管理,用簡單的數(shù)據(jù)計算對汽車進行收費標(biāo)準(zhǔn)。使車主更清楚了解停車場的信息,車主可以根據(jù)系統(tǒng)的提示進行每一項的操作。</p><p> 關(guān)鍵詞:停車場管理 C語言 數(shù)據(jù)結(jié)構(gòu) 棧 隊列</p><p><b> 目 錄</b></p><p> 1設(shè)計內(nèi)容和要求1</p><p><b>
7、; 1.1設(shè)計內(nèi)容1</b></p><p><b> 1.2設(shè)計要求1</b></p><p><b> 2 概要設(shè)計2</b></p><p> 2.1 棧的抽象數(shù)據(jù)類型定義2</p><p> 2.2 模塊的劃分4</p><p>&l
8、t;b> 3 詳細設(shè)計5</b></p><p> 3.1 數(shù)據(jù)類型的定義5</p><p> 3.2 主要模塊的算法流程圖5</p><p> 3.3 主要模塊的算法描述7</p><p> 4 軟件的測試13</p><p><b> 5 總結(jié)16</b&g
9、t;</p><p><b> 參考文獻17</b></p><p><b> 致謝18</b></p><p><b> 附錄19</b></p><p><b> 1設(shè)計內(nèi)容和要求</b></p><p><
10、b> 1.1設(shè)計內(nèi)容</b></p><p> 假設(shè)停車場是一個可以停放n輛汽車的狹長通道,且只有一個大門可供汽車進出。汽車在停車場內(nèi)按車輛到達時間的先后順序,依次由北向南排列(大門在最南端,最先到達的第一輛車停放在車場的最北端),若車場內(nèi)已停滿n輛車,那么后來的車只能在門外的便道上等候,一旦有車開走,則排在便道上的第一輛車即可開入;當(dāng)停車場內(nèi)某輛車要離開時,在它之后進入的車輛必須先退出車場
11、為它讓路,待該輛車開出大門外,其他車輛再按原次序進入車場,每輛停放在車場的車在它離開時必須按它停留的時間長短交納費用(在便道上停車不收費)。試為停車場編制按上述要求進行管理的模擬程序。</p><p><b> 1.2設(shè)計要求</b></p><p> 以棧模擬停車場,以隊列模擬便道。每一組輸入數(shù)據(jù)包括三個數(shù)據(jù)項:汽車“到達”或“離去”信息、汽車牌照號碼、到達或離
12、去的時刻。對每一組輸入數(shù)據(jù)進行操作后的輸出信息為:若是車輛到達,則輸出汽車在停車場內(nèi)或便道上的停車位置(停車位從北向南依次編號);若是車輛離去,則輸出汽車在停車場內(nèi)停留的時間和應(yīng)交納的費用。程序退出時,應(yīng)將停車場的當(dāng)前情況保存在磁盤上,以便下次運行程序時能恢復(fù)到上次退出時的狀態(tài)。</p><p><b> 2 概要設(shè)計</b></p><p> 2.1 棧的抽象
13、數(shù)據(jù)類型定義</p><p> ?。?)棧的抽象數(shù)據(jù)類型定義</p><p> AST Stack{</p><p> 數(shù)據(jù)對象:D={ai|ai∈ElemSet,i=1,2,...,n, n≥0}</p><p> 數(shù)據(jù)關(guān)系:R1={<ai-1,ai>|ai-1,ai∈D,i=2,...,n}</p><
14、;p> 約定an端為棧頂,a1端為棧底。</p><p><b> 基本操作:</b></p><p> InitStack(&S)</p><p> 操作結(jié)果:構(gòu)造一個空棧S。</p><p> DestroyStack(&S)</p><p> 初始條件:棧S
15、已存在。</p><p> 操作結(jié)果:棧S被銷毀。</p><p> ClearStack(&S)</p><p> 初始條件:棧S已存在。</p><p> 操作結(jié)果:將棧S清為空棧。</p><p> StackEmpty(S)</p><p> 初始條件:棧S已存在。&
16、lt;/p><p> 操作結(jié)果:若棧S為空棧,則返回TRUE,否則FALSE。</p><p> StackLength(s)</p><p> 初始條件:棧S已存在。</p><p> 操作結(jié)果:返回S的元素個數(shù),既棧的長度。</p><p> GetTop(S,&e)</p><p
17、> 初始條件:棧S已存在且非空。</p><p> 操作結(jié)果:用e返回S的棧頂元素。</p><p> Push(&S,e)</p><p> 初始條件:棧S已存在。</p><p> 操作結(jié)果:插入元素e為新的棧頂元素。</p><p> Pop(&S,&e)</p&g
18、t;<p> 初始條件:棧S已存在且非空。</p><p> 操作結(jié)果:刪除S的棧頂元素,并用e返回其值。</p><p> StackTraverse(S,visit())</p><p> 初始條件:棧S已存在且非空。</p><p> 操作結(jié)果:從棧底到棧頂依次對S的每個數(shù)據(jù)元素調(diào)用函數(shù)visit()。一旦vis
19、it()失敗,則操作失效。</p><p> }ADT Stack</p><p> ?。?)隊列的抽象數(shù)據(jù)類型定義</p><p> ADT Queue{</p><p> 數(shù)據(jù)對象:D={ai|ai∈ElemSet,i=1,2,...,n,n≥0}</p><p> 數(shù)據(jù)關(guān)系:R1={<ai-1,ai
20、>|ai-1,ai∈D,i=2,...,n}</p><p> 約定其中a1端為隊列頭,an為隊列尾。</p><p><b> 基本操作:</b></p><p> InitQueue(&Q)</p><p> 操作結(jié)果:構(gòu)造一個空隊列Q。</p><p> Destro
21、yQueue(&Q)</p><p> 初始條件:隊列Q已存在。</p><p> 操作結(jié)果:隊列Q被銷毀,不再存在。</p><p> ClearQueue(&Q)</p><p> 初始條件:隊列Q已存在。</p><p> 操作結(jié)果:將Q清為空隊列。</p><p&g
22、t; QueueEmpty(Q)</p><p> 初始條件:隊列Q已存在。</p><p> 操作結(jié)果:若Q為空隊列,則返回TRUE,否則FALSE。</p><p> QueueLength(Q)</p><p> 初始條件:隊列Q已存在。</p><p> 操作結(jié)果:返回Q的元素個數(shù),即隊列的長度。&
23、lt;/p><p> GetHead(Q,&e)</p><p> 初始條件:Q為非空隊列。</p><p> 操作結(jié)果:用e返回的隊頭元素。</p><p> EnQueue(&Q,e)</p><p> 初始條件:隊列Q已存在。</p><p> 操作結(jié)果:插入元素e
24、為Q的新的隊尾元素。</p><p> DeQueue(&Q,&e)</p><p> 初始條件:Q為非空隊列。</p><p> 操作結(jié)果:刪除Q的隊頭元素,并用e返回其值。</p><p> QueueTraverse(Q,visit())</p><p> 初始條件:Q已存在且非空。&l
25、t;/p><p> 操作結(jié)果:從隊頭到隊尾,依次對Q的每個數(shù)據(jù)元素調(diào)用函數(shù)visit()。一旦visit() 失敗,則操作失敗。</p><p> }ADT Queue </p><p><b> 2.2 模塊的劃分</b></p><p> 該系統(tǒng)主要有7個模塊,即:主函數(shù)模塊、棧模塊(模擬停車場)、隊列
26、模塊(模擬便道)、汽車進入模塊、汽車離開模塊、系統(tǒng)信息保存模塊、系統(tǒng)輸出顯示模塊。</p><p><b> 3 詳細設(shè)計</b></p><p> 3.1 數(shù)據(jù)類型的定義</p><p> typedef struct time</p><p><b> {</b></p>
27、<p> int hour; </p><p> int min; </p><p> }Time; //時間結(jié)點 </p><p> typedef struct carnode</p><p><b> { </b></p><p> char num[10
28、]; </p><p> Time reach; </p><p> Time leave; </p><p> }Car; //車輛信息結(jié)點 </p><p> typedef struct node</p><p><b> { </b></p>&
29、lt;p> Car *stack[100]; </p><p> int top; </p><p> }SqStack; //定義棧表示車位 </p><p> typedef struct car</p><p><b> { </b></p><p><
30、b> int num;</b></p><p> Car *data; </p><p> struct car *next; </p><p> }QNode; </p><p> typedef struct Node</p><p><b> { </
31、b></p><p> QNode *front; </p><p> QNode *rear; </p><p> }LinkQueue; //用隊列表示便道道</p><p> 3.2 主要模塊的算法流程圖</p><p><b> 圖4.1 界面顯示</b></p
32、><p><b> 圖4.2 汽車進入</b></p><p><b> 圖4.3汽車離開</b></p><p> 3.3 主要模塊的算法描述</p><p> (1)汽車進入停車場: </p><p> int arrive(SqStack *In,LinkQue
33、ue *W,int n) //車輛到達 (把元素要入棧中)</p><p> { Car *p; QNode *t; </p><p> p=(Car *)malloc(sizeof(Car)); flushall(); </p><p> printf("\n停車場還有%d個停車位(若停車位為0,車可先進入便道等待)"
34、;,n-In->top);</p><p> printf("\n請輸入車牌號碼:"); gets(p->num); </p><p> if(In->top<n) //停車場未滿,車進車場 </p><p> { In->top++;</p><p> printf
35、("\n停車的位置:%d號停車位。",In->top); </p><p> printf("\n請輸入車到達的時間格式為“**:**”:"); </p><p> scanf("%d:%d",&(p->reach.hour),&(p->reach.min));</p>&l
36、t;p> fprintf(fpout,"車牌號為%s的汽車在%d:%d時進入停車場的%d號車位\n",p->num,p->reach.hour,p->reach.min,In->top);</p><p> In->stack[In->top]=p;</p><p> printf("請按任意鍵返回")
37、;getch(); </p><p> return(1); </p><p><b> } </b></p><p> else //停車場已滿,車進便道 </p><p> { printf("\n停車位已滿,該車須在便道等待!"); </p><p&
38、gt; fprintf(fpout,"\n停車位已滿,車牌號為%s車須在便道等待!\n",p->num); </p><p> t=(QNode *)malloc(sizeof(QNode)); </p><p> t->data=p; t->next=NULL; W->rear->next=t; W->re
39、ar=t; </p><p> printf("請按任意鍵返回"); getch();</p><p> return(1); </p><p><b> } </b></p><p><b> } </b></p><p> 開始
40、定義汽車節(jié)點指針P和t,先判斷停車場內(nèi)是否有空位,若In->top<n則汽車進入停車場,然后停車場的棧頂In->top 加1表示增加了新的車輛,接著輸入進入車輛的信息。如果停車場沒有空位,則車進入便道,就是把元素壓入隊列中。</p><p> (2)汽車離開停車場:</p><p> void leave(SqStack *In,SqStack *Out,LinkQu
41、eue *W) //車輛離開 </p><p> { int room; Car *p,*t; QNode *q; </p><p> //判斷車場內(nèi)是否有車 </p><p> if(In->top>0) //有車 </p><p> { while(1) //輸入離開車輛的信息 &l
42、t;/p><p> { printf("\n請輸入車在停車場的位置(1-%d):",In->top); scanf("%d",&room); if(room>=1&&room<=In->top) break; </p><p><b> } </b></p&g
43、t;<p> while(In->top>room) //車輛離開 </p><p> { Out->top++; </p><p> Out->stack[Out->top]=In->stack[In->top]; </p><p> In->stack[In->top]=
44、NULL; In->top--; </p><p><b> } </b></p><p> p=In->stack[In->top]; </p><p> In->stack[In->top]=NULL; In->top--; </p><p> wh
45、ile(Out->top>=1) </p><p> { In->top++; </p><p> In->stack[In->top]=Out->stack[Out->top]; </p><p> Out->stack[Out->top]=NULL; Out->top--;
46、 </p><p><b> } </b></p><p> feiyong(p,room); </p><p> //判斷通道上是否有車及車站是否已滿 </p><p> if(W->front!=W->rear) //便道的車輛進入停車場 </p><p> {
47、q=W->front->next; t=q->data; In->top++; </p><p> printf("\n現(xiàn)在停車場有空位了,便道的%s號車將進入停車場第%d號停車位。",t->num,In->top); </p><p> printf("\n請輸入現(xiàn)在的時間格式為“**:**”:"
48、;); </p><p> scanf("%d:%d",&(t->reach.hour),&(t->reach.min));</p><p> fprintf(fpout,"現(xiàn)在停車場有空位了,便道的%s號車在%d:%d時進入停車場第%d號停車位。\n\n",t->num,In->top,t->r
49、each.hour,t->reach.min);</p><p> W->front->next=q->next; if(q==W->rear);W->rear=W->front; In->stack[In->top]=t; free(q);</p><p><b> } </b></p>
50、<p><b> } </b></p><p> else {printf("\n停車場里沒有車\n");</p><p> fprintf(fpout,"\n停車場里沒有車\n");}//沒車</p><p> printf("請按任意鍵返回");getch
51、();</p><p><b> }</b></p><p> 首先定義一個整型變量room,用來記錄要離開的車輛在停車場的位置,定義車輛結(jié)點指針p和t和隊列結(jié)點指針q,然后判斷停車場內(nèi)是否有車,如果有車,就輸入要離開的車輛在停車場的位置。若棧頂位置In->top大于要離開的車位置room,在要離開的車輛后面的車就要先離開,開到臨時停車場,,因此Out所表示
52、的臨時棧的棧頂top加1,用來表示臨時停車場增加1輛車;接著把該車的信息拷貝到棧Out中,然后刪除棧In的棧頂。直到要離開的車輛后面的車都開到臨時停車場之后,該車才離開,離開之后,該車的信息結(jié)點In->stack[In->top]置空,然后棧頂In->top減1。之后就把臨時停車場的車開回停車場里,因此停車場的棧頂In->top 加1,然后就把臨時停車場的車結(jié)點的信息拷貝到停車場的車結(jié)點上,接著刪除臨時停車場車的
53、結(jié)點。最后判斷(W->front!=W->rear)即便道上是否有車滿,如果便道有車且停車場未滿,通道的車便可進入停車場,此時指針q指向便道的頭,即隊頭,然后停車場的棧頂In->top 加1以便增加新的車輛,接著輸入要進停車場的車的信息,然后便道隊列的頭結(jié)點指向原隊列中第二輛車的結(jié)點,接</p><p> ?。?)顯示停車場的出入信息</p><p> void xia
54、nshi1(SqStack *S) //列表輸出車場信息 </p><p> { int i; </p><p> if(S->top>0) //判斷停車場內(nèi)是否有車 </p><p> { printf("\n車場:"); printf("\n 位置 到達時間 車牌號\n"); &
55、lt;/p><p> fprintf(fpout,"\n\車場:"); fprintf(fpout,"\n 位置 到達時間 車牌號\n");</p><p> for(i=1;i<=S->top;i++) </p><p> { printf(" %d\t",i); </p
56、><p> printf("%d:%d ",S->stack[i]->reach.hour,S->stack[i]->reach.min); </p><p> puts(S->stack[i]->num); fprintf(fpout," %d\t",i); fprintf(fpout,"
57、;%d:%d ",S->stack[i]->reach.hour,S->stack[i]->reach.min); </p><p> fprintf(fpout,"%s",S->stack[i]->num); </p><p><b> } </b></p><p
58、><b> } </b></p><p> else{ printf("\n停車場里沒有車"); </p><p> fprintf(fpout,"\n停車場里沒有車"); } </p><p><b> } </b></p><p&g
59、t; void xianshi2(LinkQueue *W) //顯示便道信息 </p><p> { QNode *p; p=W->front->next; </p><p> if(W->front!=W->rear) //判斷通道上是否有車 </p><p> { printf("\n便道中車輛的
60、號碼為:\n"); </p><p> fprintf(fpout,"\n便道中車輛的號碼為:\n"); </p><p> while(p!=NULL) </p><p><b> { </b></p><p> puts(p->data->num);
61、fprintf(fpout,"%s",p->data->num);</p><p> p=p->next; </p><p><b> } </b></p><p><b> } </b></p><p> else {printf(&qu
62、ot;\n便道里沒有車\n"); fprintf(fpout,"\n便道里沒有車\n\n");}</p><p> printf("請按任意鍵返回");getch();</p><p><b> } </b></p><p> 先顯示停車場的信息,首先判斷停車場里是否有車,如果有就輸出
63、車輛信息即車位,車牌號和到達時間。如果停車場里沒有車,就輸出停車場沒有車。再判斷便道上是否有車,如果有車就輸出便道上車輛的車牌號,若沒有就輸出便道上沒有車。最后按任意鍵返回。</p><p> ?。?)計算汽車離開時的收費情況</p><p> void feiyong(Car *p,int room) //輸出停車站車的信息 </p><p> { i
64、nt A1,A2,B1,B2; int s,sum; </p><p> printf("\n請輸入車離開的時間格式為“**:**”:"); </p><p> scanf("%d:%d",&(p->leave.hour),&(p->leave.min)); </p><p> pri
65、ntf("\n車牌號碼:"); puts(p->num); </p><p> printf("\n車到達的時間是: %d:%d",p->reach.hour,p->reach.min); </p><p> printf("車離開的時間是: %d:%d",p->leave.hour,p->
66、leave.min); </p><p> fprintf(fpout,"車牌號為%s的汽車在%d:%d時離開,",p->num,p->leave.hour,p->leave.min); </p><p> A1=p->reach.hour; A2=p->reach.min; </p><p> B
67、1=p->leave.hour; B2=p->leave.min;</p><p> s=(B1*60+B2)-(A1*60+A2);</p><p> if(s%60>=30) sum=(s/60+1)*3;</p><p> else sum=s/60*3;</p><p> printf("您所需
68、繳納的費用為: %d元\n",sum); </p><p> fprintf(fpout,"車主需繳納的費用為: %d元\n\n",sum); </p><p> free(p); </p><p><b> }</b></p><p> 首先讓戶主輸入離開時的時間,然后根據(jù)
69、該車到達的時間算出該車總停留的時</p><p> 間,再根據(jù)每小時3元,不足一小時四舍五入即s=(B1*60+B2)-(A1*60+A2);</p><p> if(s%60>=30) sum=(s/60+1)*3;else sum=s/60*3;算出總的費用。</p><p><b> 。</b></p><
70、p><b> 4 軟件的測試</b></p><p> 進入界面輸入停車場的最大容量為6:</p><p> 圖5.1系統(tǒng)初始化界面圖</p><p> 2.輸入8輛車進入停車場,并顯示停車場的信息:</p><p> 圖4.2汽車進入停車場的示意圖</p><p> 圖4.3汽
71、車進入便道示意圖</p><p> 圖4.4顯示停車場的信息圖</p><p> 3.使3號位的車離開車場,離開后便道上的車進入停車場,并顯示汽車離開后停車場的信息:</p><p> 圖4.5汽車離開車場,便道上的車進入車場的示意圖</p><p> 圖4.6顯示停車場的信息</p><p><b>
72、; 4.退出系統(tǒng):</b></p><p> 圖4.7退出系統(tǒng)示意圖</p><p> 5.停車場的所有出入信息保存在estdout.pc2文件中:</p><p> 圖4.8車場信息存入磁盤的部分示意圖</p><p><b> 5 總結(jié)</b></p><p> 通過這
73、次數(shù)據(jù)結(jié)構(gòu)的程序設(shè)計,我更加理解了棧和隊列這兩種重要的線性結(jié)構(gòu)。知道了棧和隊列的抽象數(shù)據(jù)類型的定義,知道了棧的順序存儲結(jié)構(gòu)和隊列的鏈?zhǔn)酱鎯Y(jié)構(gòu)的定義和算法描述,也充分的理解了用棧和隊列實現(xiàn)模擬停車場的基本原理。學(xué)會了編一些簡單的停車場的程序。這次的程序設(shè)計總的來說我覺得編寫的還可以,但是仍然有一些地方需要完善,如把停車場的信息保存在磁盤上,就有一些困難。后面還是通過和同學(xué)一起討論才有了大概的思路,知道了從哪里下手。剛開始看到這個程序任務(wù)
74、時,我還不知道從哪里下手,該怎么編寫,腦袋里沒有一點頭緒,很盲目,但是后來把題目多讀了幾遍,詳細地對題目分析和思考,理清楚思緒后,就知道具體應(yīng)該做什么了。編完這個數(shù)據(jù)結(jié)構(gòu)的程序我真的學(xué)會了許多東西,它結(jié)合了我上學(xué)期學(xué)習(xí)的C語言和這學(xué)期學(xué)習(xí)的數(shù)據(jù)結(jié)構(gòu)的知識。讓我學(xué)會把所學(xué)的知識充分有效的運用到了一起。又一次鞏固了C語言和數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ)知識。這個過程中的點點滴滴在課堂上是體會不到的,這個過程中的收獲在課堂上也是學(xué)不到的。</p>
75、<p> 在編寫這個程序的過程中,我從無從下手到有一點點思路,再到慢慢動手自己編寫,最后把編寫的琳琳碎碎的代碼結(jié)合在一起。過程中遇到麻煩有懊惱過,想放棄過,但是最后還是一步一步走過來了。我想不管遇到什么困難,我都不要輕言放棄,因為只要不放棄就還有希望,如果放棄了就什么機會也沒有了。</p><p> 在此我也非常感謝我同學(xué)的幫助,他們給我講解程序中的一些小錯誤,或者不懂的地方,幫我理清一些小混亂
76、,減少了我的一些困惑。還要特別感謝我的指導(dǎo)老師。感謝老師的細心認真的輔導(dǎo),讓我對數(shù)據(jù)結(jié)構(gòu)這門課程有了更深的了解,也懂得了更多知識,他教我怎么理解和分析問題,在剛開始沒有頭緒時,他給我一些小小的提示,在編程序的過程中,遇到棘手的問題,他也耐心認真的給我講解。真的非常感謝你們。</p><p><b> 參考文獻</b></p><p> [1] 嚴蔚敏 吳偉明. 數(shù)
77、據(jù)結(jié)構(gòu)(C語言版).北京:清華大學(xué)出版社 2011: 44-65</p><p> [2] 何欽銘 顏暉. C語言程序設(shè)計 .高等教育出版社 2008</p><p> [3] 譚浩強 張基溫. C語言程序設(shè)計教程 .高等教育出版社 2006</p><p> [4] Stephen Prata. C Primer Plus(第五版)中文版 .北京:人民郵電出
78、版社 2005: 353-376</p><p><b> 致謝</b></p><p> 非常感謝指導(dǎo)老師的幫助,還有我的同學(xué)和室友的幫助。謝謝!</p><p><b> 向蘇虹</b></p><p> 2012年 7月5日</p><p><b>
79、 附錄</b></p><p> #include <stdio.h> </p><p> #include <stdlib.h> </p><p> #include <conio.h></p><p> #include <assert.h></p>
80、<p> typedef struct time{</p><p> int hour; </p><p> int min; </p><p> }Time; //時間結(jié)點 </p><p> typedef struct carnode</p><p> { char num[
81、10]; </p><p> Time reach; </p><p> Time leave; </p><p> }Car; //車輛信息結(jié)點 </p><p> typedef struct node</p><p> { Car *stack[100]; </p>
82、<p> int top; </p><p> }SqStack; //定義棧表示車位 </p><p> typedef struct car</p><p> { int num;</p><p> Car *data; </p><p> struct car *next;
83、 </p><p> }QNode; </p><p> typedef struct Node</p><p> { QNode *front; </p><p> QNode *rear; </p><p> }LinkQueue; //用隊列表示便道道 </p>&l
84、t;p> int n ; FILE *fpout;</p><p> void InitStack(SqStack *); //初始化棧 </p><p> int InitQueue(LinkQueue *); //初始化隊列 </p><p> int arrive(SqStack *,LinkQueue *,int); //車輛到達 &l
85、t;/p><p> void leave(SqStack *,SqStack *,LinkQueue *); //車輛離開 </p><p> void xianshi(SqStack,LinkQueue); //顯示停車場信息 </p><p> void feiyong(Car *p,int room);</p><p> vo
86、id InitStack(SqStack *s) //初始化棧 { </p><p> int i; s->top=0; </p><p> for(i=0;i<=n;i++) </p><p> s->stack[s->top]=NULL; </p><p><b> }
87、</b></p><p> int InitQueue(LinkQueue *Q) //初始化隊列 </p><p> { Q->front=(QNode *)malloc(sizeof(QNode)); </p><p> if(Q->front!=NULL) </p><p><b>
88、 { </b></p><p> Q->front->next=NULL; Q->rear=Q->front; </p><p> return(1); </p><p><b> } </b></p><p> else return(-1); <
89、;/p><p><b> } </b></p><p> int arrive(SqStack *In,LinkQueue *W,int n) //車輛到達 (把元素要入棧中) </p><p><b> { </b></p><p> Car *p; QNode *t; <
90、/p><p> p=(Car *)malloc(sizeof(Car)); </p><p> flushall(); </p><p> printf("\n停車場還有%d個停車位(若停車位為0,車可先進入便道等待)",n-In->top);</p><p> printf("\n請輸入車牌號
91、碼:"); </p><p> gets(p->num); </p><p> if(In->top<n) //停車場未滿,車進車場 </p><p> { In->top++;</p><p> printf("\n停車的位置:%d號停車位。",In->to
92、p); </p><p> printf("\n請輸入車到達的時間格式為“**:**”:"); </p><p> scanf("%d:%d",&(p->reach.hour),&(p->reach.min));</p><p> fprintf(fpout,"車牌號為%s的汽車
93、在%d:%d時進入停車場的%d號車位\n",p->num,p->reach.hour,p->reach.min,In->top);</p><p> In->stack[In->top]=p;</p><p> printf("請按任意鍵返回");getch(); </p><p> retu
94、rn(1); </p><p><b> } </b></p><p> else //停車場已滿,車進便道 </p><p> { printf("\n停車位已滿,該車須在便道等待!"); </p><p> fprintf(fpout,"\n停車位已滿,車牌號為%
95、s車須在便道等待!\n",p->num); </p><p> t=(QNode *)malloc(sizeof(QNode)); </p><p> t->data=p; t->next=NULL; </p><p> W->rear->next=t; W->rear=t; </p>
96、;<p> printf("請按任意鍵返回"); getch();</p><p> return(1); </p><p><b> } </b></p><p><b> } </b></p><p> void leave(SqStac
97、k *In,SqStack *Out,LinkQueue *W) </p><p> { //車輛離開 </p><p> int room; Car *p,*t; QNode *q; </p><p> //判斷車場內(nèi)是否有車 </p><p> if(In->top>0) //有車 </
98、p><p> { while(1) //輸入離開車輛的信息 </p><p> { printf("\n請輸入車在停車場的位置(1-%d):",In->top); </p><p> scanf("%d",&room); </p><p> if(room>=1&
99、amp;&room<=In->top) break; </p><p><b> } </b></p><p> while(In->top>room) //車輛離開 </p><p> { Out->top++; </p><p> Out->st
100、ack[Out->top]=In->stack[In->top]; </p><p> In->stack[In->top]=NULL; In->top--; </p><p><b> } </b></p><p> p=In->stack[In->top]; <
101、/p><p> In->stack[In->top]=NULL; In->top--; </p><p> while(Out->top>=1) </p><p> { In->top++; </p><p> In->stack[In->top]=Out->sta
102、ck[Out->top]; </p><p> Out->stack[Out->top]=NULL; Out->top--; </p><p><b> } </b></p><p> feiyong(p,room); </p><p> //判斷通道上是否有車及車站是否已
103、滿 </p><p> if(W->front!=W->rear) //便道的車輛進入停車場 </p><p> { q=W->front->next; </p><p> t=q->data; In->top++; </p><p> printf("\n現(xiàn)在停車場有空位
104、了,便道的%s號車將進入停車場第%d號停車位。",t->num,In->top); </p><p> printf("\n請輸入現(xiàn)在的時間格式為“**:**”:"); </p><p> scanf("%d:%d",&(t->reach.hour),&(t->reach.min));<
105、;/p><p> fprintf(fpout,"現(xiàn)在停車場有空位了,便道的%s號車在%d:%d時進入停車場第%d號停車位。\n\n",t->num,In->top,t->reach.hour,t->reach.min);</p><p> W->front->next=q->next;</p><p>
106、 if(q==W->rear) W->rear=W->front; </p><p> In->stack[In->top]=t; </p><p><b> free(q);</b></p><p><b> } </b></p><p><b
107、> } </b></p><p> else {printf("\n停車場里沒有車\n");</p><p> fprintf(fpout,"\n停車場里沒有車\n");}//沒車</p><p> printf("請按任意鍵返回");getch();</p>&
108、lt;p><b> }</b></p><p> void xianshi1(SqStack *S) //列表輸出車場信息 </p><p> { int i; </p><p> if(S->top>0) //判斷停車場內(nèi)是否有車 </p><p><b> {
109、</b></p><p> printf("\n車場:"); </p><p> printf("\n 位置 到達時間 車牌號\n"); </p><p> fprintf(fpout,"\n\n車場:"); </p><p> fprintf(fpo
110、ut,"\n 位置 到達時間 車牌號\n");</p><p> for(i=1;i<=S->top;i++) </p><p> { printf(" %d\t",i); </p><p> printf("%d:%d ",S->stack[i]->reac
111、h.hour,S->stack[i]->reach.min); </p><p> puts(S->stack[i]->num); </p><p> fprintf(fpout," %d\t",i); </p><p> fprintf(fpout,"%d:%d ",S->
112、;stack[i]->reach.hour,S->stack[i]->reach.min); </p><p> fprintf(fpout,"%s",S->stack[i]->num); </p><p><b> } </b></p><p><b> } &
113、lt;/b></p><p> else{ printf("\n停車場里沒有車"); </p><p> fprintf(fpout,"\n停車場里沒有車"); } </p><p><b> } </b></p><p> void xianshi2(Li
114、nkQueue *W) //顯示便道信息 </p><p> { QNode *p; </p><p> p=W->front->next; </p><p> if(W->front!=W->rear) //判斷通道上是否有車 </p><p><b> { </b>
115、;</p><p> printf("\n便道中車輛的號碼為:\n"); </p><p> fprintf(fpout,"\n便道中車輛的號碼為:\n"); </p><p> while(p!=NULL) </p><p> { puts(p->data->num)
116、; </p><p> fprintf(fpout,"%s",p->data->num);p=p->next; </p><p><b> } </b></p><p><b> } </b></p><p> else {printf(&
117、quot;\n便道里沒有車\n"); fprintf(fpout,"\n便道里沒有車\n\n");}</p><p> printf("請按任意鍵返回");getch();</p><p><b> } </b></p><p> void xianshi(SqStack S,Link
118、Queue W) </p><p> { xianshi1(&S); //顯示停車場信息 xianshi2(&W); //顯示停便道信息 } </p><p> void feiyong(Car *p,int room) //輸出停車站車的信息 </p><p> { int A1,A2,B1,B2; int s,s
119、um; </p><p> printf("\n請輸入車離開的時間格式為“**:**”:"); </p><p> scanf("%d:%d",&(p->leave.hour),&(p->leave.min)); </p><p> printf("\n車牌號碼:")
120、; puts(p->num); </p><p> printf("\n車到達的時間是: %d:%d",p->reach.hour,p->reach.min); </p><p> printf("車離開的時間是: %d:%d",p->leave.hour,p->leave.min); </p>
121、<p> fprintf(fpout,"車牌號為%s的汽車在%d:%d時離開,",p->num,p->leave.hour,p->leave.min); </p><p> A1=p->reach.hour; A2=p->reach.min; </p><p> B1=p->leave.hour; B
122、2=p->leave.min;</p><p> s=(B1*60+B2)-(A1*60+A2);if(s%60>=30) sum=(s/60+1)*3;</p><p> else sum=s/60*3;</p><p> printf("您所需繳納的費用為: %d元\n",sum); </p><p&g
123、t; fprintf(fpout,"車主需繳納的費用為: %d元\n\n",sum); </p><p> free(p); </p><p><b> }</b></p><p> void main() </p><p> { fpout=fopen("estd
124、out.pc2","a");</p><p> assert(fpout);</p><p> int n; //存儲車庫最大容量</p><p> SqStack In,Out; LinkQueue Wait; int ch; </p><p> InitStack(&In); //
125、初始化停車場 InitStack(&Out); //初始化讓路的臨時棧 </p><p> InitQueue(&Wait); //初始化便道 </p><p> while(1) </p><p> { printf("--------------------歡迎使用停車場管理系統(tǒng)-----------------
126、---\n");</p><p> printf("本停車場的收費標(biāo)準(zhǔn)為3元/小時,不足一小時部分四舍五入\n");</p><p> printf("請輸入停車場的的最大容量:");scanf("%d",&n);</p><p> printf("您輸入的停車場容量為%d
127、位\n",n);</p><p> printf(".................操 作 菜 單...............\n");</p><p> printf(" 1車輛到達2車輛離開3停車場信息4退出系統(tǒng)\n請您選擇選擇需要操作的:\n");</p><p> whil
128、e(1) </p><p> { ch=getch();</p><p> switch(ch) </p><p> { case 49:arrive(&In,&Wait,n);break; //車輛到達 </p><p> case 50:leave(&In,&Out,&W
129、ait);break; //車輛離開 </p><p> case 51:xianshi(In,Wait);break; //輸出車站信息</p><p> case 52:{printf("謝謝使用!");exit(0);} //退出主程序 </p><p> default:printf("\n按鍵無效,請重新按鍵選擇
130、!");</p><p> }//49-52分別表示"1"-"4"這四個按鍵的鍵值</p><p> system("CLS");</p><p> printf("--------------------歡迎使用停車場管理系統(tǒng)--------------------\n"
131、;);</p><p> printf("本停車場的收費標(biāo)準(zhǔn)為3元/小時,不足一小時部分四舍五入\n");</p><p> printf("您輸入的停車場容量為%d位\n",n);</p><p> printf("................. 操 作 菜 單............
132、..........\n");</p><p> printf(" 1為車輛到達 2為車輛離開 3為停車場信息 4為退出系統(tǒng)\n請您選擇選擇需要操作的:\n");</p><p><b> } </b></p><p><b> } </b></p>
溫馨提示
- 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. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計---停車場管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-- 停車場管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--停車場管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計《停車場管理系統(tǒng)》
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計——停車場管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--停車場管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-停車場管理
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--停車場管理
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計停車場管理
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-停車場管理
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--停車場管理
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告---停車場管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--停車場管理系統(tǒng) (2)
- 停車場管理系統(tǒng)數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)停車場管理系統(tǒng)課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)停車場管理系統(tǒng)課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告停車場管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)停車場管理系統(tǒng)課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--停車場管理系統(tǒng)報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計停車場管理報告
評論
0/150
提交評論