C语言课程设计报告停车场管理系统1副本.docx
- 文档编号:10493482
- 上传时间:2023-02-14
- 格式:DOCX
- 页数:16
- 大小:75.76KB
C语言课程设计报告停车场管理系统1副本.docx
《C语言课程设计报告停车场管理系统1副本.docx》由会员分享,可在线阅读,更多相关《C语言课程设计报告停车场管理系统1副本.docx(16页珍藏版)》请在冰豆网上搜索。
C语言课程设计报告停车场管理系统1副本
停车场管理系统设计报告
班级:
计算机1402
姓名:
赵超
学号:
143230229
题目及要求
[要求]
设有一个可以停放n辆汽车的狭长停车场,它只有一个大门可以供车辆进出。
车辆按到达停车场时间的早晚依次从停车场最里面向大门口停放(最先到达的第一辆车放在停车场的最里面)。
如果停车场已放满n辆车,则后来的车辆只能在停车场大门外的便道上等待,一旦停车场内有车开走,则排在便道上的第一辆国就进入停车场。
停车场内如有某辆车要走,在它之后进来的车都必须退出停车场为它让路,待其开出停车场后,这些车辆再依原来的次序进场。
每辆车在离开停车场时,都应根据它在停车场内停留的时间长短交费。
如果停留在便道上的车未进停车场就要离去,允许其离去,不收停车费,并且其他在便道上等待的车辆的次序不变。
编制一程序模拟停车场管理。
(1)进入2辆车,车均进车库,便道上无车,并进行列表显示
(3)再进入3辆车,第一辆车进车库,后2辆车在便道等待,同时输出等待的提示作息,最后列表显示以查寻结果,此时车库已满,便道上有2辆车在等待。
(4)离开停车位1和停车位2上的2辆车,同时输入它们离开的时间,并计算它们的应交费用。
离开后,车库里便有空出2个停车位,这时便道里的前2辆车就可进入车库,便道里的进入车库里要记录它们进去的时间,开始计时收费。
最后进行列表显示,车库里应仍有3辆车,便道应无车。
说明:
该系统仍可继续工作,随时在主菜单中选择4便可退出系统。
源代码
#include
#include
#include
#defineMAX3/*车库容量*/
#defineprice0.5/*每车每分钟费用*/
typedefstructtime
{
inthour;
intmin;
}Time;/*时间结点*/
typedefstructnode
{
charnum[10];
Timereach;
Timeleave;
}CarNode;/*车辆信息结点*/
typedefstructNODE
{
CarNode*stack[MAX+1];
inttop;
}Moni_Cheku;
typedefstructcar
{
CarNode*data;
structcar*next;
}QueueNode;
typedefstructNode
{
QueueNode*head;
QueueNode*rear;
}Moni_Biandao;
voidInitStack(Moni_Cheku*);/*初始化车库*/
intInitQueue(Moni_Biandao*);/*初始化便道*/
intArrival(Moni_Cheku*,Moni_Biandao*);/*车辆到达*/
voidLeave(Moni_Cheku*,Moni_Cheku*,Moni_Biandao*);/*车辆离开*/
voidList(Moni_Cheku,Moni_Biandao);/*显示车库和便道的存车信息*/
voidmain()
{
Moni_ChekuEnter,Temp;
Moni_BiandaoWait;
intch;
InitStack(&Enter);/*初始化车站*/
InitStack(&Temp);/*初始化让路的临时链表*/
InitQueue(&Wait);/*初始化便道*/
printf("\n");
printf("^_^欢迎进入停车场管理系统1!
^_^\n");
printf("\n");
printf("提示!
(1).该车库的最大容量为:
%d;\n",MAX);
printf("
(2).该车库的收费标准为:
%4.2f元/(辆*分钟).\n",price);
while
(1)
{
printf("********************主菜单********************\n");
printf("1.车辆到达");
printf("2.车辆离开");
printf("3.列表显示");
printf("4.退出系统\n");
printf("**********************************************\n");
printf("请选择(1-4):
[]\b\b");
while
(1)
{
scanf("%d",&ch);
if(ch>=1&&ch<=4)break;
elseprintf("错误!
请重选(1-4):
[]\b\b");
}
switch(ch)
{
case1:
Arrival(&Enter,&Wait);break;/*车辆到达*/
case2:
Leave(&Enter,&Temp,&Wait);break;/*车辆离开*/
case3:
List(Enter,Wait);break;/*打印列表信息*/
case4:
exit(0);/*退出主程序*/
default:
break;
}
}
}
voidInitStack(Moni_Cheku*s)/*初始化车库*/
{
inti;
s->top=0;
for(i=0;i<=MAX;i++)
s->stack[s->top]=NULL;
}
intInitQueue(Moni_Biandao*Q)/*初始化便道*/
{
Q->head=(QueueNode*)malloc(sizeof(QueueNode));
if(Q->head!
=NULL)
{
Q->head->next=NULL;
Q->rear=Q->head;
return
(1);
}
elsereturn(-1);
}
voidPRINT(CarNode*p,introom)/*输出出库车的信息*/
{
intA1,A2,B1,B2;
printf("请输入离开的时间:
/**:
**/");
scanf("%d:
%d",&(p->leave.hour),&(p->leave.min));
printf("离开车辆的车牌号为:
");
puts(p->num);
printf("其到达时间为:
%d:
%d\n",p->reach.hour,p->reach.min);
printf("离开时间为:
%d:
%d\n",p->leave.hour,p->leave.min);
A1=p->reach.hour;
A2=p->reach.min;
B1=p->leave.hour;
B2=p->leave.min;
printf("应交费用为:
%4.2f元",((B1-A1)*60+(B2-A2))*price);
free(p);
}
intArrival(Moni_Cheku*Enter,Moni_Biandao*W)/*车辆到达*/
{
CarNode*p;
QueueNode*t;
p=(CarNode*)malloc(sizeof(CarNode));
flushall();
printf("请输入车牌号(例如:
中CUG888):
");
gets(p->num);
if(Enter->top { Enter->top++; printf("该车在车库位置%d.\n",Enter->top); printf("请输入到达时间(**: **): "); scanf("%d: %d",&(p->reach.hour),&(p->reach.min)); Enter->stack[Enter->top]=p; return (1); } else/*车库已满,车进便道*/ { printf("该车须在便道等待! \n"); t=(QueueNode*)malloc(sizeof(QueueNode)); t->data=p; t->next=NULL; W->rear->next=t; W->rear=t; return (1); } } voidLeave(Moni_Cheku*Enter,Moni_Cheku*Temp,Moni_Biandao*W)/*车辆离开*/ { inti,room; CarNode*p,*t; QueueNode*q; /*判断车库内是否有车*/ if(Enter->top>0)/*有车*/ { printf("请输入车在车库的位置(1--%d): ",Enter->top);/*输入车辆离开的信息*/ while (1) { scanf("%d",&room); if(room>=1&&room<=Enter->top)break; elseprintf("错误! 请重选: "); } while(Enter->top>room)/*车辆离开*/ { Temp->top++; Temp->stack[Temp->top]=Enter->stack[Enter->top]; Enter->stack[Enter->top]=NULL; Enter->top--; } p=Enter->stack[Enter->top]; Enter->stack[Enter->top]=NULL; Enter->top--; while(Temp->top>=1) { Enter->top++; Enter->stack[Enter->top]=Temp->stack[Temp->top]; Temp->stack[Temp->top]=NULL; Temp->top--; } PRINT(p,room);/*判断通道上是否有车及车库是否已满*/ if((W->head! =W->rear)&&Enter->top { q=W->head->next; t=q->data; Enter->top++; printf("\n便道的%s号车进入车场第%d位置.",t->num,Enter->top); printf("\n请输入现在的时间(**: **): "); scanf("%d: %d",&(t->reach.hour),&(t->reach.min)); W->head->next=q->next; if(q==W->rear)W->rear=W->head; Enter->stack[Enter->top]=t; free(q); } elseprintf("\n便道里没有车.\n"); } elseprintf("车库里没有车! \n");/*没车*/ } voidList1(Moni_Cheku*S)/*列表显示车库信息*/ { inti; if(S->top>0)/*判断车库内是否有车*/ { printf("车库: "); printf("\n位置到达时间车牌号\n"); for(i=1;i<=S->top;i++) { printf("%d",i); printf("%d: %d",S->stack[i]->reach.hour,S->stack[i]->reach.min); puts(S->stack[i]->num); } } elseprintf("车库里没有车\n"); } voidList2(Moni_Biandao*W)/*列表显示便道信息*/ { QueueNode*p; p=W->head->next; if(W->head! =W->rear)/*判断便道上是否有车*/ { printf("在便道里等待的车辆的号码为: \n"); while(p! =NULL) { puts(p->data->num); p=p->next; } } elseprintf("便道里没有车.\n"); } voidList(Moni_ChekuS,Moni_BiandaoW) { intflag,tag; flag=1; while(flag) { printf("**********查看**********\n"); printf("1.车库2.便道3.返回\n"); printf("************************\n"); printf("请选择(1-3): []\b\b"); while (1) { scanf("%d",&tag); if(tag>=1&&tag<=3)break; elseprintf("错误! 请重选(1-3): []\b\b"); } switch(tag) { case1: List1(&S);break;/*列表显示车库信息*/ case2: List2(&W);break;/*列表显示便到信息*/ case3: flag=0;break; default: break; } } } ^_^欢迎进入停车场管理系统1! ^_^ (2).该车库的收费标准为: 0.50元/(辆*分钟). ********************主菜单******************** 1.车辆到达2.车辆离开3.列表显示4.退出系统 ********************************************** 请选择(1-4): [2] 车库里没有车! ********************主菜单******************** 1.车辆到达2.车辆离开3.列表显示4.退出系统 ********************************************** 请选择(1-4): [8] 错误! 请重选(1-4): [1] 请输入车牌号(例如: 中CUG888): asd123 该车在车库位置1. 请输入到达时间(**: **): 12: 10 ********************主菜单******************** 1.车辆到达2.车辆离开3.列表显示4.退出系统 ********************************************** 请选择(1-4): [1] 请输入车牌号(例如: 中CUG888): fgh456 该车在车库位置2. 请输入到达时间(**: **): 12: 20 ********************主菜单******************** 1.车辆到达2.车辆离开3.列表显示4.退出系统 ********************************************** 请选择(1-4): [] 随着科技的进步,越来越多的车辆满足了人们的日常生活。 所以停车也成为了一个大问题,停车场也变得更加难管理。 这个代码可以解决这个问题,能使停车场的管理变得更方便。 既能计算停车的时间,又能统计收费。 节约了人力,变得更加智能。 方便了人们的日常生活!
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C语言课程设计报告停车场管理系统1 副本 语言 课程设计 报告 停车场 管理 系统