C语言如何实现停车场管理
这篇文章将为大家详细讲解有关C语言如何实现停车场管理,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
C语言课程设计之停车场管理问题,供大家参考,具体内容如下
1.问题描述:停车场内只有一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列(大门在最南端,最先到达的第一辆车停放在停车场的最北端),若车场内已停满n辆汽车,则后来的汽车只能在门外的便道上等候,一旦有车开走,则排在便道上的第一辆车即可开入;当停车场内某辆车要离开时,在它之后开入的车辆必须先退出车场为它让路,待该辆车开出大门外,其它车辆再按原次序进入车场,每辆停放在车场的车在它离开停车场时必须按它停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。
2.基本要求
(1)以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入的输入数据序列进行模拟管理。(2)每一组输入数据包括三个数据项:汽车“到达”或“离去”信息、汽车牌照号码及到达或离去的时刻,对每一组输入数据进行操作后的输出数据为:若是车辆到达,则输出汽车在停车场内或便道上的停车位置;若是车离去;则输出汽车在停车场内停留的时间和应交纳的费用(在便道上停留的时间不收费)。(3)栈以顺序结构实现,队列以链表结构实现。(4)按照题意要求独立进行设计,设计结束后按要求写出设计报告。
一、代码块:
#include#include #include typedefintElemType; #defineMaxSize100 #defineQNODEstructQNode typedefstructNode//车辆信息 { charAL; intNO; inttime; }Node; typedefstructStack//栈定义 { structNodedata[MaxSize]; inttop; intnum; }SqStack; QNODE//队列节点 { structNodedata; QNODE*next; }; typedefstructlinkqueue//队列结构体定义 { QNODE*front,*rear; intnum; }LinkQueue; SqStack*Init_SeqStack()//置空栈 { SqStack*s; s=(SqStack*)malloc(sizeof(SqStack)); s->top=-1; s->num=0; returns; } LinkQueue*Init_LQueue()//创建空队列 { LinkQueue*q; QNODE*p; q=(LinkQueue*)malloc(sizeof(LinkQueue)); p=(QNODE*)malloc(sizeof(QNODE)); p->next=NULL; q->front=q->rear=p; q->num=0; returnq; } intISEmpty_SeqStack(SqStack*s)//判断栈是否为空,栈为空返回1 { if(s->top==-1) return1; else return0; } intISFULL_SeqStack(SqStack*s,intn)//判断栈是否已满,若栈满返回1 { if(s->top==n-1) return1; else return0; } intISEmpty_LQueue(LinkQueue*q)//判断队列是否为空,队列为空返回1 { if(q->front==q->rear) return1; else return0; } voidIN_Lqueue(LinkQueue*q,structNodes)//入队 { QNODE*p; p=(QNODE*)malloc(sizeof(QNODE)); p->data=s; q->num++; p->next=NULL; q->rear->next=p; q->rear=p; } voidPush_SeqStack(SqStack*p,structNodes)//入栈 { p->top++; p->data[p->top]=s; p->num++; } intPOP_SeqStack(SqStack*s,structNodecar)//出栈 { SqStack*p; intt; p=Init_SeqStack(); while(s->data[s->top].NO!=car.NO)//找到车牌号为P.NO的车, { Push_SeqStack(p,s->data[s->top]); s->top--; s->num--; } t=car.time-s->data[s->top].time; s->top--; s->num--; while(ISEmpty_SeqStack(p)==0) { Push_SeqStack(s,p->data[p->top]); p->top--; p->num--; } returnt; } structNodeOut_LQueue(LinkQueue*q)//出队 { QNODE*p; p=q->front->next; q->front->next=p->next; q->num--; if(q->front->next==NULL) q->rear=q->front; returnp->data; free(p); } intmain() { SqStack*parkstack;//parkstack为表示停车场的栈 LinkQueue*parkqueue;//parkqueue为表示便道的队列 structNodecar; intn,a=0,t;//n为停车场栈的最大容量 floatf;//f为每小时收费 parkstack=Init_SeqStack(); parkqueue=Init_LQueue();//初始界面 printf("***************停车场信息查询***************\n"); printf("请输入停车场最大容量n="); scanf("%d",&n); printf("\n请输入每分钟收取费用f="); scanf("%f",&f); printf("\n请输入车辆信息\n"); scanf("%c,%d,%d",&car.AL,&car.NO,&car.time); while(car.AL!='Q') { if(car.AL=='A') {//汽车到达的情况 if(ISFULL_SeqStack(parkstack,n)==1)//栈满的情况 { IN_Lqueue(parkqueue,car);//进入队列等待 printf("这辆车在门外便道上第%d个位置\n",parkqueue->num); printf("\n"); printf("请输入车辆信息\n"); } else { Push_SeqStack(parkstack,car);//入栈 printf("这辆车在停车场内第%d个位置\n",parkstack->num); printf("\n"); printf("请输入车辆信息\n"); } } if(car.AL=='L')//汽车离开的情况 { t=POP_SeqStack(parkstack,car);//出栈 printf("这辆车停留时间为%d,收费为%f。\n",t,f*t); printf("\n"); printf("请输入车辆信息\n"); if(ISEmpty_LQueue(parkqueue)==0)//队列不为空需要进栈 Push_SeqStack(parkstack,Out_LQueue(parkqueue)); } if(car.AL=='P'&&car.NO==0&&car.time==0)//显示停车场的车数 { printf("停车场的车数为%d\n",parkstack->num); printf("\n"); printf("请输入车辆信息\n"); } if(car.AL=='W'&&car.NO==0&&car.time==0)//显示候车场的车数 { printf("候车场的车数为%d\n",parkqueue->num); printf("\n"); printf("请输入车辆信息\n"); } scanf("%c,%d,%d",&car.AL,&car.NO,&car.time); } printf("输入结束\n"); return1; }
二、运行:
关键字:A——arrive;L——leave;P——park;Q——quit;W——wait.
关于“C语言如何实现停车场管理”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
推荐阅读
windows安装touble c
近期有些网友想要了解windows?安装touble的相关情况,小编通过整理给您分享一下。为什么现在还需要TurboC?在当今V...
C/C++如何获取CAN信号
C/C++如何获取CAN信号本篇内容主要讲解“C/C++如何获取C...
C语言怎么通过二分查找实现猜数字游戏
C语言怎么通过二分查找实现猜数字游戏本文小编为大家详细介绍“C语言...
C语言数据结构中的线性表怎么使用
C语言数据结构中的线性表怎么使用这篇文章主要介绍“C语言数据结构中...
C语言的数据结构怎么理解
C语言的数据结构怎么理解这篇文章主要介绍了C语言的数据结构怎么理解...
C语言与C++中内存管理的方法
C语言与C++中内存管理的方法这篇文章主要介绍了C语言与C++中内...
C语言链式队列与循环队列怎么实现
C语言链式队列与循环队列怎么实现这篇文章主要介绍了C语言链式队列与...
C语言冒泡排序怎么实现
C语言冒泡排序怎么实现这篇文章主要介绍了C语言冒泡排序怎么实现的相...
C语言如何实现斐波那契数列
C语言如何实现斐波那契数列这篇文章主要介绍了C语言如何实现斐波那契...
C语言如何实现无符号数和有符号数间的运算
C语言如何实现无符号数和有符号数间的运算本篇内容主要讲解“C语言如...