#include <stdio.h>
#include<stdlib.h>
#include<malloc.h>
//函数返回状态代码
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
#define INFEASIBLE -1
#define OVERFLOW -2
#define SIZE 4//停车场位置数
typedef int Status;
typedef struct Car1{//车
int number;
int ar_time;
}CarNode;
typedef struct{//栈,模拟停车场
CarNode *base;
CarNode *top;
int stacksize;
}Park;
//队列,模拟便道
typedef struct Car2{
int number;
int ar_time;
struct Car2 *next;
}*CarPtr;
typedef struct{//便道
CarPtr front;
CarPtr rear;
int length;
}Shortcut;
Status InitStack(Park &P){//初始化停车场
P.base=(CarNode*)malloc(SIZE*sizeof(Car1));
if(!P.base) exit(OVERFLOW);
P.top=P.base;
P.stacksize=0;
return OK;
}
Status Push(Park &P,CarNode e){//车进入停车场
*P.top++=e;
++P.stacksize;
return OK;
}
Status Pop(Park &P,CarNode &e){//车离开停车场
if(P.top==P.base)
printf("停车场为空。");
else
{
e=*--P.top;
--P.stacksize;
}
return OK;
}
Status InitQueue(Shortcut &S){//初始化便道
S.front=S.rear=(CarPtr)malloc(sizeof(Car2));
if(!S.front||!S.rear) exit(OVERFLOW);
S.front->next=NULL;
S.length=0;
return OK;
}
Status EnQueue(Shortcut &S,int number,int ar_time){//车进入便道
CarPtr p;
p=(CarPtr)malloc(sizeof(Car2));
if(!p) exit(OVERFLOW);
p->number=number;
p->ar_time=ar_time;
p->next=NULL;
S.rear->next=p;
S.rear=p;
++S.length;
return OK;
}
Status DeQueue(Shortcut &S,CarPtr &w){//车离开便道
if(S.length == 0)
printf("通道为空。");
else
{
w = S.front->next;
S.front->next=S.front->next->next;
--S.length;
}
return OK;
}
Status Arrival(Park &P,Shortcut &S){//对进站车辆的处理
int number,ar_time;
printf("请输入车牌号:");
scanf("%d",&number);
printf("进场时刻:");
scanf("%d",&ar_time);
if(P.stacksize<SIZE)
{
CarNode c;
c.number=number;
c.ar_time=ar_time;
Push(P,c);
printf("该车应停在第%d号车道。\n",P.stacksize);
}
else
{
EnQueue(S,number,ar_time);
printf("停车场已满,请暂时停在便道的第%d个位置。\n",S.length);
}
return OK;
}
Status Leave(Park &P,Park &P1,Shortcut &S){//对离站车辆的处理
int number,le_time,flag=1,money,ar_time;
printf("请输入车牌号:");
scanf("%d",&number);
printf("出场时刻:");
scanf("%d",&le_time);
CarNode e,m;
CarPtr w;
while(P.stacksize)
{
Pop(P,e);
if(e.number==number)
{
flag=0;
money=(le_time-e.ar_time)*2;
ar_time=e.ar_time;
break;
}
Push(P1,e);
}
while(P1.stacksize)
{
Pop(P1,e);
Push(P,e);
}
// 车从停车场中出
if (flag == 0)
{
if(S.length!=0)
{
DeQueue(S,w);
m.ar_time=le_time;
m.number=w->number;
Push(P,m);
free(w);
printf("车牌号为%d的车已由便道进入停车场\n",m.number);
}
printf("停车费为%d, 占用车位数为%d\n",money,P.stacksize);
}
else
{
printf("停车场不存在牌号为%d的车\n", number);
}
return OK;
}
int main()
{
int m=1;
char flag;//选项
Park P,Q;
Shortcut S;
InitStack(P);
InitStack(Q);
InitQueue(S);
while(m)
{
printf("\n 停车场management \n");
printf("A 汽车进车场\n");
printf("D 汽车出车场\n");
printf("E 退出程序\n");
printf("选择(A,D,E): ");
scanf("%c",&flag);
switch(flag)
{
case 'A':
Arrival(P,S);break;
case 'D':
Leave(P,Q,S);break;
case 'E':
m=0;
break;
default:
printf("sorry,智商被压制了");
break;
}
while (flag != '\n')
scanf("%c",&flag);
}
}
TING-CHE-CHANG.rar_che_tingchechang·com_停车场 c
版权申诉
192 浏览量
2022-09-24
06:59:43
上传
评论
收藏 1KB RAR 举报
四散
- 粉丝: 51
- 资源: 1万+
最新资源
- IMG_0694.GIF
- 基于图像的三维模型重建C++源代码+文档说明(高分课程设计)
- 基于聚焦法的工件立体测量方案,根据数据进行三维重建 使用HALCON处理图像,MATLAB拟合数据+源代码+数据集+效果图
- 锄战三国村 修改:货币使用不减 v1.10(2) 原创 (中文).apk
- 基于python实现的单目双目视觉三维重建+源代码+图像图片(高分课程设计)
- 基于C+++OPENCV的全景图像拼接源码(课程设计)
- 基于Python+OpenCV对多张图片进行全景图像拼接,消除鬼影,消除裂缝+源代码+文档说明+界面截图(高分课程设计)
- 基于C++实现的全景图像拼接源码(课程设计)
- 基于SIFT特征点提取和RASIC算法实现全景图像拼接python源码+文档说明+界面截图+详细注释(95分以上课程大作业)
- 基于matlab实现眼部判别的疲劳检测系统+源代码+全部数据+文档说明+详细注释+使用说明+截图(高分课程设计)
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈