C语言实现停车场管理

 更新时间:2019年12月27日 14:40:09   作者:夏.谨之  
这篇文章主要为大家详细介绍了C语言课程设计之停车场管理问题,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

C语言课程设计之停车场管理问题,供大家参考,具体内容如下

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

2.基本要求

(1)以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入的输入数据序列进行模拟管理。
(2)每一组输入数据包括三个数据项:汽车“到达”或“离去”信息、汽车牌照号码及到达或离去的时刻,对每一组输入数据进行操作后的输出数据为:若是车辆到达,则输出汽车在停车场内或便道上的停车位置;若是车离去;则输出汽车在停车场内停留的时间和应交纳的费用(在便道上停留的时间不收费)。
(3)栈以顺序结构实现,队列以链表结构实现。
(4)按照题意要求独立进行设计,设计结束后按要求写出设计报告。

一、代码块:

#include <stdio.h>
#include <malloc.h>
#include <stdlib.h>
typedef int ElemType;
#define MaxSize 100
#define QNODE struct QNode

typedef struct Node //车辆信息
{
 char AL;
 int NO;
 int time;
}Node;
typedef struct Stack //栈定义
{
 struct Node data[MaxSize];
 int top;
 int num;
}SqStack;
QNODE        //队列节点
{
 struct Node data;
 QNODE *next;
};
typedef struct linkqueue    //队列结构体定义
{
 QNODE *front,*rear;
 int num;
}LinkQueue;

SqStack *Init_SeqStack() //置空栈
{
 SqStack *s;
 s=(SqStack*)malloc(sizeof(SqStack));
   s->top=-1;
 s->num=0;
 return s;
}
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;
 return q;
}
int ISEmpty_SeqStack(SqStack *s) //判断栈是否为空,栈为空返回1
{
 if(s->top ==-1)
 return 1;
 else
 return 0;
}

int ISFULL_SeqStack(SqStack *s,int n) //判断栈是否已满,若栈满返回1
{
 if(s->top==n-1)
 return 1;
 else
 return 0;
}
int ISEmpty_LQueue(LinkQueue *q) //判断队列是否为空,队列为空返回1
{
 if(q->front==q->rear)
 return 1;
 else
 return 0;
}

void IN_Lqueue( LinkQueue *q,struct Node s)  //入队
{
 QNODE *p;
 p=(QNODE*)malloc(sizeof(QNODE));
 p->data=s;
 q->num++;
 p->next=NULL;
 q->rear->next =p;
 q->rear =p;
}
void Push_SeqStack(SqStack *p,struct Node s)  //入栈
{
 p->top ++;
 p->data[p->top]=s;
 p->num++;
}
int POP_SeqStack(SqStack *s,struct Node car)//出栈
{
 SqStack *p;
 int t;
  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--;
 }
 return t;
}

struct Node Out_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;
 return p->data;
 free(p);
}
int main()
{
 SqStack *parkstack;  //parkstack为表示停车场的栈
 LinkQueue *parkqueue;    //parkqueue为表示便道的队列
 struct Node car;
 int n,a=0,t;        //n为停车场栈的最大容量
 float f;          //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");
 return 1;
}

二、运行:

关键字:A——arrive;L——leave;P——park;Q——quit;W——wait.

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言运算符与表达式

    C语言运算符与表达式

    这篇文章主要介绍了C语言运算符与表达式,表达式是C语言的主体。在C语言中,表达式由操作符和操作数组成,更多相关介绍需要的小伙伴可以参考下面文章内容
    2022-07-07
  • c语言如何实现DES加密解密

    c语言如何实现DES加密解密

    这篇文章主要介绍了c语言如何实现DES加密解密问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • 详解C++ functional库中的仿函数使用方法

    详解C++ functional库中的仿函数使用方法

    仿函数(functor)又称之为函数对象(function object),实际上就是 重载了()操作符 的 struct或class。本文将详细讲解C++中仿函数的使用方法,需要的可以参考一下
    2022-04-04
  • C++关于Makefile的详解含通用模板

    C++关于Makefile的详解含通用模板

    今天小编就为大家分享一篇关于C++关于Makefile的详解含通用模板,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • C++ 中实现把EXCEL的数据导入数据库(ACCESS、MSSQL等)实例代码

    C++ 中实现把EXCEL的数据导入数据库(ACCESS、MSSQL等)实例代码

    这篇文章主要介绍了C++ 中实现把EXCEL的数据导入数据库(ACCESS、MSSQL等)实例代码的相关资料,需要的朋友可以参考下
    2017-04-04
  • c++ 防止头文件重复引入的三种方法

    c++ 防止头文件重复引入的三种方法

    这篇文章主要介绍了c++ 防止头文件重复引入的三种方法,帮助大家更好的理解和学习使用c++,感兴趣的朋友可以了解下
    2021-02-02
  • OpenCV reshape函数实现矩阵元素序列化

    OpenCV reshape函数实现矩阵元素序列化

    reshape函数是OpenCV中一个很有用的函数,不仅可以改变矩阵的通道数,还可以对矩阵元素进行序列化。本文将主要介绍如何通过reshape实现矩阵元素序列化,需要的小伙伴可以参考一下
    2021-12-12
  • 使用C++实现Excel文件与CSV之间的相互转换

    使用C++实现Excel文件与CSV之间的相互转换

    这篇文章主要为大家详细介绍了如何使用C++实现Excel文件与CSV之间的相互转换,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2023-06-06
  • C语言简单实现快速排序

    C语言简单实现快速排序

    快速排序是一种不稳定排序,这篇文章主要为大家详细介绍了C语言简单实现快速排序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • C语言模拟实现strstr函数的示例代码

    C语言模拟实现strstr函数的示例代码

    strstr是C语言中的函数,作用是返回字符串中首次出现子串的地址。本文将用C语言模拟实现strstr函数,感兴趣的小伙伴可以跟随小编一起学习一下
    2022-07-07

最新评论