ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:18.10KB ,
资源ID:8690540      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/8690540.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构课程设计停车场管理系统设计报告.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据结构课程设计停车场管理系统设计报告.docx

1、数据结构课程设计停车场管理系统设计报告int main() Initialization(); CarNode car; SqStack Park,TempPark; LinkQueue Q; InitStack(Park); InitStack(TempPark); InitQueue(Q); while(scanf(%c%d%d,&car.event,&car.num,&car.time)&(car.event!=e&car.event!=E) getchar(); /除去输入结束时的回车 switch(car.event) case A: case a:Arrive(Park,Q,car

2、);break; case D: case d:Leave(Park,TempPark,Q,car);break; default: printf(您的第一个数据输入有误!n);break; printf(程序结束,谢谢使用!n); return 0; 2)分别构造空栈和空队列栈:Status InitStack(SqStack &S) /构造一个空栈 S.Stacksize=0; S.base=(CarNode*)malloc(MAX)*sizeof(CarNode); if(!S.base) exit(OVERFLOW); printf(存储空间分配失败); S.top=S.base; r

3、eturn OK;队列:Status InitQueue(LinkQueue &Q) /构造一个空队列(带头结点) Q.front=Q.rear=(QueueNode*)malloc(sizeof(QueueNode); if(!Q.front) exit(OVERFLOW); printf(存储空间分配失败); Q.front-next=NULL; Q.queuesize=0; return OK; 3)车辆到达处理 Status Arrive(SqStack &S,LinkQueue &Q,CarNode &e) /车辆到达处理 if(S.top-1)-time=e.time) /时间处理

4、 if(!Check_Stack(S,e)&!Check_Queue(Q,e) /是否已存在 if(S.top-S.basenum) /车辆处在栈顶 Pop(S, a); leatime=e.time; leanum=e.num; entertime=a.time; printf(车辆进入车库时间:%dt现在(离开)时间:%dt停留时间:%dtn,entertime,leatime,leatime-entertime); else /车辆处在栈中间 do Pop(S,a); /从栈中依次退出 Push(TempS,a); /依次进入临时栈 while(S.top-1)-num!=e.num);

5、/直到top指针下一个位置的num=车牌号 Pop(S, a); /该车离开 leatime=e.time; leanum=e.num; entertime=a.time; printf(车进入停车场时间:%dt现在(离开)时间:%dt停留时间:%dtn,entertime,leatime,leatime-entertime); do /其余车辆按原来次序返回停车场 Pop(TempS,a); Push(S,a); while(TempS.top!=TempS.base);/条件与上面不同,此时是全部回去 cost=(leatime-entertime)*price; if(cost=0) p

6、rintf(您的车牌号为 %d 的车应交纳的费用是:%dn,leanum,cost); if(Q.front!=Q.rear) /队列不空的话从便道进停车场 DeQueue(Q,a); if(a.timenext-data.num!=e.num); DeQueue(Q,e); /前面的车进入队尾 printf(您的车牌号为 %d 的车辆未进入车库从便道直接离开,费用为0!n,e.num); return true;2主要设计程序如下:#include#include#include#define MAX 2 /停车场容量#define price 2 /单价#define OK 1#defin

7、e FALSE 0#define TRUE 1#define ERROR -1#define OVERFLOW -2typedef int Status;/=typedef struct CarNode char event; int num; int time;CarNode; /车辆信息结点typedef struct SqStack CarNode *base; CarNode *top; int Stacksize;SqStack; /栈(停车场)typedef struct QNode CarNode data; struct QNode *next;QueueNode; /便道结点

8、typedef struct LinkQueue QueueNode *front; QueueNode *rear; int queuesize;LinkQueue; /队列(便道)/=Status InitStack(SqStack &S) /构造一个空栈 S.Stacksize=0; S.base=(CarNode*)malloc(MAX)*sizeof(CarNode); if(!S.base) exit(OVERFLOW); printf(存储空间分配失败); S.top=S.base; return OK;/=Status InitQueue(LinkQueue &Q) /构造一个

9、空队列(带头结点) Q.front=Q.rear=(QueueNode*)malloc(sizeof(QueueNode); if(!Q.front) exit(OVERFLOW); printf(存储空间分配失败); Q.front-next=NULL; Q.queuesize=0; return OK;/=Status GetTop(SqStack S,CarNode &e) /返回栈顶元素 if(S.top=S.base) return ERROR; e=*(S.top-1); return TRUE;/=Status Pop(SqStack &S,CarNode &e) /删除栈顶元素

10、 if(S.top=S.base) return ERROR; e=*-S.top; return OK;/=Status Push(SqStack &S,CarNode e)/插入元素为新的栈顶元素(在栈不满的前提下) if(S.top-S.base=MAX) return FALSE; *S.top+=e; return OK;/=Status DeQueue(LinkQueue &Q,CarNode &e) /删除队头元素(带头结点) if(Q.rear=Q.front) return ERROR; QueueNode *p=Q.front-next; e=p-data; Q.front

11、-next=p-next; if(p=Q.rear) Q.rear=Q.front; free(p); Q.queuesize-; return OK;/=Status EnQueue(LinkQueue &Q,CarNode e) /插入新的队尾元素 QueueNode *p=(QueueNode*)malloc(sizeof(QueueNode); if(!p) exit(OVERFLOW); p-data=e; p-next=NULL; Q.rear-next=p; Q.rear=p; Q.queuesize+; return OK;/=Status Check_Stack(SqStac

12、k &S,CarNode e)/车辆到达时车库内是否有同名车 CarNode *Temp=S.base; while(Temp!=(S.top)&(Temp-num!=e.num) Temp+; if(Temp=S.top) return FALSE; else return TRUE;/=Status Check_Queue(LinkQueue &Q,CarNode e)/车辆到达时便道上是否有同名车 QueueNode *Temp=Q.front; while(Temp!=Q.rear) & (Temp-data.num!=e.num) Temp=Temp-next; if(Temp=Q.

13、rear) & (Temp-data.num!=e.num) return FALSE; else return TRUE;/=Status Arrive(SqStack &S,LinkQueue &Q,CarNode &e) /车辆到达处理 if(S.top-1)-time=e.time) /时间处理 if(!Check_Stack(S,e)&!Check_Queue(Q,e) /是否已存在 if(S.top-S.baseMAX) Push(S,e); printf(成功进入停车场,在%d号车库!n,S.top-S.base); return OK; else EnQueue(Q,e); printf(停车场已满,车辆进入便道,在%d号车位!n,Q.queuesize); else printf(该牌照的车已存在,输入有误,请重新输入n); return OK; else printf(时间输入有误,请重新输入!n); return FALSE; /=Status Leave(SqStack &S,SqStack &TempS,LinkQueue &Q,CarNode &e) /车辆离开处理 CarNode a; int leatime,leanum; int entertime;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1