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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

本科毕业设计论文数据结构项目课程报告停车场管理系统.docx

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

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

3、include #define OK 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;

4、LinkQueue;主函数void 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( = = = = 欢迎使用停车场管理系统 = = = =

5、= = = = = = 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 = =

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(

7、n = = = = = = = = = = = = = = = = = = = = = 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

8、请选择n); printf(n = = = = = = = = = = = = = = = = = = = = = 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 (timein

9、fo); strcpy(p-leave.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); f

10、ree(p);/消费计算函数车辆到达函数,获取车辆信息,判断是否有车位,进行入栈或入队操作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 (ti

11、meinfo) ); /asctime (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-nu

12、m); getchar(); if (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);

13、getchar(); return 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请按任意键返回); getchar(); return OK; getchar();车辆离开函数,如果是最前面的车离开,后面

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

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