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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

停车场管理系统.docx

1、停车场管理系统 数据结构项目课程报告 一、 问题描述及分析题目要求: 设停车场内只有一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列(大门在最南端,最先到达的第一辆车停放在车场的最北端),若车场内已停满n辆汽车,则后来的汽车只能在门外的便道上等候,一旦有车开走,则排在便道上的第一辆车即可开入;当停车场内某辆车要离开时,在它之后开入的车辆必须先退出车场为它让路,待该车辆开出大门外,其他车辆再按原次序进入车场,每辆车停放在车场的车在它离开停车场时必须按它停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。分析:由题目

2、只有一个大门进出并且“先到后处理”可知,应使构造栈模拟停车场,进入离开停车场即入栈出栈的过程;而便道等候的汽车符合“先到先处理”原则 ,应构造线性队列模拟;构造存储结构,存放车辆信息,车牌号,到达离开时间;通过time.h头文件中的函数获取汽车到来以及离开时间,利用时间差计算价钱。主要模块如下图:二、 功能模块及数据结构描述头文件、宏定义以及存储结构结构体定义相关类型的链表空间有顺序栈的定义、链队、车辆信息结构体、时间计算结构体、车辆位置字符型结构体数组和循环单链表存储下一个地址空间。#include #include #include #include #include #define OK

3、 1#define ERROR 0typedef struct time1 char times100; long time2;time1;typedef struct node char num10; time1 reach; time1 leave;Car;typedef struct Stack Car *stack100; int top;SqStack;typedef struct car Car *data; struct car *next;QNode;typedef struct Node QNode *front; QNode *rear;LinkQueue;主函数void

4、main() SqStack In, Out; LinkQueue Wait; int ch; int MAX; float price; printf(请输入停车场的容量:); scanf(%d, &MAX); printf(请输入停车场的收费标准(元 / 小时) :); scanf(%f, &price); InitStack(&In, MAX); InitStack(&Out, MAX); InitQueue(&Wait); while (1) system(color 0A); printf( = = = = 欢迎使用停车场管理系统 = = = = = = = = = = n); pr

5、intf(输入的停车场容量为%d位,费用为%2.1f元 / 小时, 请按任意键进入系统, MAX, price); getchar(); system(CLS); printf( = = = = 欢迎使用停车场管理系统 = = = = = = = = = n); printf(您输入的停车场容量为%d位,费用为%2.1f元 / 小时。n, MAX, price); printf(n = = = = = = = = = = = = = n); printf(1)车辆到达n(2)车辆离开n(3)停车场信息n(4)退出系统n请选择n); printf(n = = = = = = = = = = =

6、= = = n); while (1) printf(请输入操作的序号); scanf(%d, &ch); switch (ch) case 1: arrive(&In, &Wait, MAX, price); break; case 2: leave(&In, &Out, &Wait, MAX, price); break; case 3: info(In, Wait); break; case 4: system(CLS); printf(n = = = = = = = = = = = = = = n); printf( 谢谢使用!n); printf(n = = = = = = = =

7、= = = = = = = = = = = = = n); exit(0); default:printf(n按键无效,请重新按键选择); getchar(); system(CLS); printf( = = = = = 欢迎使用停车场管理系统 = = = = = n); printf(您输入的停车场容量为%d位,费用为%2.1f元 / 小时。n, MAX, price); printf(n = = = = = = = = = = = = = = = = = = = = n); printf(1)车辆到达n(2)车辆离开n(3)停车场信息n(4)退出系统n请选择n); printf(n =

8、= = = = = = = = = = = = = = = = = = = = n); 费用计算函数,通过时间差计算费用void print(Car *p, int room, int MAX, float price) time_t rawtime; struct tm * timeinfo; long A1, A2, B1, B2; time ( &rawtime ); timeinfo = localtime ( &rawtime ); p-leave.time2=rawtime; printf(n车离开的时间为:%s ,asctime (timeinfo); strcpy(p-leav

9、e.times,asctime (timeinfo); printf(n车牌号码:); puts(p-num); printf(n车到达的时间是: %s , p-reach.times); printf(n车离开的时间是: %s , p-leave.times); A1=p-leave.time2; A2=p-reach.time2; B1=p-leave.time2-p-reach.time2; if(B1=0) printf(n费用为: %2.1f元, price); else printf(n费用为: %2.1f元, B1/3600*price); free(p);/消费计算函数车辆到达

10、函数,获取车辆信息,判断是否有车位,进行入栈或入队操作int arrive(SqStack *In, LinkQueue *W, int MAX, float price) Car *p; QNode *t; time_t rawtime; struct tm * timeinfo; /time ( &rawtime ); / 获取时间,以秒计,从1970年1月一日起算,存于rawtime /timeinfo = localtime ( &rawtime ); /转为当地时间,tm 时间结构 /printf ( 当前系统时间: %s, asctime (timeinfo) ); /asctim

11、e (timeinfo); / 转为标准ASCII时间格式: p = (Car *)malloc(sizeof(Car); printf( = = = = = = = = = = = 欢迎使用停车场管理系统 = = = = = = = = = = = n); printf(您输入的停车场容量为%d位,费用为%2.1f元 / 小时。n, MAX, price); printf(停车场还有%d停车位, 车可先进入便道等待, MAX - In-top); printf(n请输入车牌号码(例:警A1035) :); getchar(); scanf(%s, p-num); getchar(); if

12、(In-top reach.time2=rawtime; timeinfo = localtime ( &rawtime ); In-top+; printf(停车的位置:%d号停车位。, In-top); printf(n车到达的时间为%s: ,asctime (timeinfo); strcpy(p-reach.times,asctime (timeinfo); In-stackIn-top = p; printf(请按任意键返回n); printf(n = = = = = = = = = = = = = = = = = = = = = = = n); getchar(); return

13、OK; else printf( = = = = = 欢迎使用停车场管理系统 = = = = = = = = = n); printf(您输入的停车场容量为%d位,费用为%2.1f元 / 小时。n, MAX, price); printf(n = = = = = = = = = = = = = = = = = = = = = n); printf(停车位已满,该车须在便道等待!); t = (QNode *)malloc(sizeof(QNode); t-data = p; t-next = NULL; W-rear-next = t; W-rear = t; printf(n请按任意键返回)

14、; getchar(); return OK; getchar();车辆离开函数,如果是最前面的车离开,后面的车必须都进行出栈操作进入到另一个栈中让需要离开的车离开后再重新进入;如果便道有车那么便道的前面的车即先入队的车进行出队入栈void leave(SqStack *In, SqStack *Out, LinkQueue *W, int MAX, float price) int place; Car *p, *t; QNode *q; time_t rawtime; struct tm * timeinfo; system(CLS); if (In-top0) while (1) pri

15、ntf( = = = = 欢迎使用停车场管理系统 = = = = = = = = = n); printf(您输入的停车场容量为%d位,费用为%2.1f元 / 小时。n, MAX, price); printf(n = = = = = = = = = = = = = = = = = = = = = = = = = = n); printf(请输入车在停车场的位置(1 - %d):, In-top); scanf(%d, &place); if (place = 1 & place top) break; while (In-topplace) Out-top+; Out-stackOut-to

16、p = In-stackIn-top; In-stackIn-top = NULL; In-top-; p = In-stackIn-top; In-stackIn-top = NULL; In-top-; while (Out-top = 1) In-top+; In-stackIn-top = Out-stackOut-top; Out-stackOut-top = NULL; Out-top-; print(p, place, MAX, price); if (W-front != W-rear) & In-topfront-next; t = q-data; In-top+; prin

17、tf(n便道的%s号车进入车场第%d号停车位。, t-num, In-top); printf(n车到达的时间: %s ,asctime (timeinfo); t-reach.time2=rawtime; strcpy(t-reach.times,asctime (timeinfo); W-front-next = q-next; if (q = W-rear) W-rear = W-front; In-stackIn-top = t; free(q); else printf(n = = = = = = = = = = = = = = = = = = = = = = = = = n); p

18、rintf(停车场里没有车n); printf(n请按任意键返回); printf(nn = = = = = = = = = = = = = = = = = = = = = = = = = = n); getchar(); getchar();停车场信息函数,遍历队列和栈能知道便道中和停车场中车辆信息void info1(SqStack *S) int i; if (S-top0) printf(n 停车场n); for (i = 1; i top; i+) printf(n 位置: n %dn, i); printf( 到达时间:n%s 车牌号: n %sn, S-stacki-reach.

19、times,S-stacki-num); else printf(n = = = = = = = = = = = = = = = = = = = = = n); printf(停车场里没有车); void info2(LinkQueue *W) QNode *p; p = W-front-next; if (W-front != W-rear) printf(n便道中车辆的号码为:n); while (p != NULL) printf(%sn, p-data-num); p = p-next; else printf(n便道里没有车n); printf(n请按任意键返回n); printf(

20、nn = = = = = = = = = = = = = = = = = = = = = n); getchar();void info(SqStack S, LinkQueue W) system(CLS); info1(&S); info2(&W); getchar();队列和栈的初始化void InitStack(SqStack *s, int MAX) int i; s-top = 0; for (i = 0; i stacks-top = NULL;int InitQueue(LinkQueue *Q) Q-front = (QNode *)malloc(sizeof(QNode);

21、 if (Q-front != NULL) Q-front-next = NULL; Q-rear = Q-front; return OK; else return ERROR;/队列和栈初始函数三、 主要算法流程描述及部分核心算法流程描述1.车辆到达停车场其中车辆到达时需要用户输入车辆信息,接着要判断栈是否已满,如当前栈未满,则进行入栈操作,即车辆进入停车场;如果栈已满,则车辆必须进入便道等待。2. 车辆进入停车场车辆进入,则进行入栈操作,即将车辆信息结点进行入栈操作。3. 车辆离开停车场车辆的离开,则需要另设一个栈,给离去的汽车让路而从停车场退出来的汽车临时停放,也用顺序栈实现,车辆离开

22、后需检查便道内是否有车辆等待,若有等待车辆则进行便道内的车辆进入停车场的操作,即将车辆信息结点进行入栈操作,输入当前时间后开始计费,最后进行出队操作,表示车辆已离开便道。核心算法车辆到达停车场获取车辆到达时间是车辆进入停车场车辆离开停车场四、 系统使用说明运行环境为VC+6.0,如果需要在VS上运行需要改动scanf函数为scanf_s运行截图附:源码#include #include #include #include #include #define OK 1#define ERROR 0typedef struct time1 char times100; long time2;time

23、1;typedef struct node char num10; time1 reach; time1 leave;Car;typedef struct Stack Car *stack100; int top;SqStack;typedef struct car Car *data; struct car *next;QNode;typedef struct Node QNode *front; QNode *rear;LinkQueue;void print(Car *p, int room, int MAX, float price);int arrive(SqStack *In, L

24、inkQueue *W, int MAX, float price);void leave(SqStack *In, SqStack *Out, LinkQueue *W, int MAX, float price);void info1(SqStack *S);void info2(LinkQueue *W);void info(SqStack S, LinkQueue W);void InitStack(SqStack *s, int MAX);int InitQueue(LinkQueue *Q);void main() SqStack In, Out; LinkQueue Wait;

25、int ch; int MAX; float price; printf(请输入停车场的容量:); scanf(%d, &MAX); printf(请输入停车场的收费标准(元 / 小时) :); scanf(%f, &price); InitStack(&In, MAX); InitStack(&Out, MAX); InitQueue(&Wait); while (1) system(color 0A); printf( = = = = 欢迎使用停车场管理系统 = = = = = = = = = = n); printf(输入的停车场容量为%d位,费用为%2.1f元 / 小时, 请按任意键进入系统, MAX, price); getchar(); system(CLS); printf( = = = = 欢迎使用停车场管理系统 = = = = = = = = = n); printf(您输入的停车场容量为%d位,费用为%2.1f元 / 小时。n, MAX, price); printf(n = = = = = = = = = = = = = n); printf(1)车辆到达n(2)车辆离开n(3)停车场信息n(4)退出系统n请选择n); printf(n = = = = = = = = = = = = = = n); while (1)

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2