千家信息网

怎么用C语言实现简易停车场管理系统

发表于:2025-11-10 作者:千家信息网编辑
千家信息网最后更新 2025年11月10日,本篇内容主要讲解"怎么用C语言实现简易停车场管理系统",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"怎么用C语言实现简易停车场管理系统"吧!问题描述:设停车
千家信息网最后更新 2025年11月10日怎么用C语言实现简易停车场管理系统

本篇内容主要讲解"怎么用C语言实现简易停车场管理系统",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"怎么用C语言实现简易停车场管理系统"吧!

问题描述:

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

由题得,此系统要实现的功能为:

(1)设计停车场内的结构。(由题分析为一个栈,因为只有一个门所以其就像数据结构中学到的栈,但是因为既要出栈又要入栈,此处我就将这个栈简化为了一个链表)

(2)当车库满时,在车库外等待的结构。(就像排队一样,先来先进后来后进,只能从一端进,另一端出)。

(3)车辆的结构,一辆车要有什么信息?首先要有这辆车的车牌号,可以用一个字符数组来存储(因为车牌不一定全是数字,还可能有汉字,英文字母等),题中要求要用要计算收费,就要知道驶入时间和驶出时间(怎样获取在下面会说到)。

算法描述:

1、刚开始定义结构类型,如车的类型,车库里的类型,车库外等待的类型。

2、声明所要用到的函数:

 void menu(Stack *cheku,SequenQueue* paidui);//开始菜单 //就是展示出菜单的函数//队列的相关操作 SequenQueue* InitQueue();//申请一个空队int EmptyQueue(SequenQueue* Q);//判断队空int FullQueue(SequenQueue* Q);//判断队满int EnQueue(SequenQueue* Q, ElemType *e);//入队int DeQueue(SequenQueue* Q, ElemType *e); //出队Stack* build();//建链表int fullstack(Stack *cheku);//判断链表满void tingche(Stack *cheku,SequenQueue* paidui);//停车的函数void likai(Stack *cheku,SequenQueue* paidui);//离开的函数void chakan(Stack *cheku,SequenQueue* paidui);//查看车库停车情况的函数

3、一些可能不理解的说明的说明。

(1). 获取时间的函数,写头文件 #include ,定义一个 time_t类型的变量starttime,starttime=time(NULL);就是获取1970年1月1日到当前的秒数,定义一个字符数组 tmp2[100],strftime(tmp2,sizeof(tmp2),"%Y-%m-%d %H:%M:%S",localtime(&q->a.starttime));用这一句就能把当前时间的年月日时分秒存进字符数组中,puts(tmp2),就得到了当前的时间。

(2). 代码中用到了Sleep函数,这个函数的功能为延时,要用到一个头文件,#include ,此函数是与(3)中的配合使用。

(3).(2)中提到的就是system("cls"),他的作用就是清屏,(2)的作用就是把结果让用户看到。故两者配合,就能得到奇效。

程序代码:

#include #include #include #include #include #define TRUE 1#define FALSE 0#define MAXSIZE 1024static int maxsize;typedef char ElemType;typedef struct{    char  num[10];//车牌    time_t starttime,endtime;//进入推出时间 }car;   //车 typedef struct Stack{    int top;    car a;    struct Stack *next;    }Stack;typedef struct{    char a[10];}dat;typedef struct {//队列结构定义   dat      data[MAXSIZE];   int      front;   int      rear; }SequenQueue;void menu(Stack *cheku,SequenQueue* paidui);//开始菜单  SequenQueue* InitQueue();//申请一个空队 int EmptyQueue(SequenQueue* Q);//判断队空 int FullQueue(SequenQueue* Q);//判断队满 int EnQueue(SequenQueue* Q, ElemType *e);//入队 int DeQueue(SequenQueue* Q, ElemType *e); //出队Stack* build();//建链表 void tingche(Stack *cheku,SequenQueue* paidui);int fullstack(Stack *cheku);void likai(Stack *cheku,SequenQueue* paidui);void chakan(Stack *cheku,SequenQueue* paidui); int main(){    Stack *cheku=build();    SequenQueue* paidui=InitQueue();    printf("请输入车库最大容量:");    scanf("%d",&maxsize);     system("cls");    menu(cheku,paidui);    return 0;}void menu(Stack *cheku,SequenQueue* paidui){    printf("**********        欢迎来停车 !        **********\n");    printf("**********        请选择一项          **********\n");    printf("**********         1 : park.          **********\n");    printf("**********         2 : leave.         **********\n");    printf("**********         3 : view.          **********\n");    printf("**********         4 : exit.          **********\n");    int option;    scanf("%d",&option);    system("cls");    switch(option)    {        case 1:        {                tingche(cheku,paidui);                menu(cheku,paidui);                break;        }        case 2:        {                likai(cheku,paidui);                menu(cheku,paidui);                break;        }        case 3:        {            chakan(cheku, paidui);           menu(cheku,paidui);            break;        }        case 4:        {            printf("**********     欢迎再次使用,谢谢!   **********\n");            break;        }        default:{            printf("**********      请输入正确的指令!    **********\n");            Sleep(1000);            menu(cheku,paidui);            system("cls");            break;        }    }}int fullstack(Stack *cheku){    if(cheku->topfront = Q->rear = 0;    return Q;}int DeQueue(SequenQueue* Q, ElemType *e){    if(EmptyQueue(Q))        return FALSE;    else    {        strcpy(e,Q->data[Q->front].a);        Q->front=(Q->front+1)%MAXSIZE;        return TRUE;    } }int EnQueue(SequenQueue* Q, ElemType *e){    if(FullQueue(Q))        {            printf("等待的车辆太多,请下次再来");            return FALSE;        }    strcpy(Q->data[Q->front].a,e);    Q->rear = (Q->rear+1)%MAXSIZE;    return TRUE;}int FullQueue(SequenQueue* Q){    if((Q->rear+1)%MAXSIZE==Q->front)    {        return TRUE;    }    else    {        return FALSE;    }}int EmptyQueue(SequenQueue* Q){    if(Q->front == Q->rear)        return TRUE;    else        return FALSE;}Stack* build(Stack *cheku,SequenQueue* paidui){    Stack* a;    a=(Stack*)malloc(sizeof(Stack));    a->top=-1;    return a;}void tingche(Stack *cheku,SequenQueue* paidui){    Stack *p;    p=(Stack *)malloc(sizeof(Stack));    printf("请输入车牌号\n");    fflush(stdin);    gets(p->a.num);    if(fullstack(cheku))    {        p->next=cheku->next;        cheku->next=p;        p->a.starttime=time(NULL);        cheku->top++;        printf("停车成功\n");        Sleep(1000);        system("cls");    }    else    {        printf("车库已满请在门口等待\n");        EnQueue(paidui,p->a.num);        Sleep(1000);        system("cls");    } }void likai(Stack *cheku,SequenQueue* paidui){    char m[10];    Stack *p,*q;    char e[10];    int n=0;    p=cheku;    if(cheku->top==-1)    {        printf("车库为空\n");        Sleep(1000);        system("cls");     }    else    {    printf("请输入离开的车牌:\n");    fflush(stdin);    gets(m);    while(p->next!='\0')    {    double money;         if(strcmp(p->next->a.num,m)==0)        {            q=p->next;            p->next=q->next;            q->a.endtime=time(NULL);            money=(q->a.endtime-q->a.starttime)*0.00139;            char tmp1[100],tmp2[100];            strftime(tmp1,sizeof(tmp1),"%Y-%m-%d  %H:%M:%S",localtime(&q->a.endtime));            strftime(tmp2,sizeof(tmp2),"%Y-%m-%d  %H:%M:%S",localtime(&q->a.starttime));            printf("停车时间:%s\n",tmp2);            printf("离开时间:%s\n",tmp1);            printf("共停%ds\n",q->a.endtime-q->a.starttime);             printf("收费%.5lf元(一小时五元)\n",money);             Sleep(3000);            free(q);            system("cls");            cheku->top--;            n++;            if(EmptyQueue(paidui)==0)            {                DeQueue(paidui,e);                Stack *d=(Stack *)malloc(sizeof(Stack));                strcpy(d->a.num,e);                d->a.starttime=time(NULL);                d->next=cheku->next;                cheku->next=d;                cheku->top++;                printf("已将等待的第一辆车进入停车场");                Sleep(1000);                system("cls");             }             break;        }        p=p->next;    }    if(n==0)    {        printf("未找到该车辆信息请重试");        Sleep(1000);        system("cls");    }}     }void chakan(Stack *cheku,SequenQueue* paidui){    if(cheku->top==maxsize-1)    {        printf("车库已满,共有%d的车辆在等候",(paidui->rear-paidui->front+MAXSIZE)%MAXSIZE);        Sleep(1000);        system("cls");    }    else    {        printf("车库还有%d个空位",maxsize-cheku->top-1);        Sleep(1000);        system("cls");    }}

到此,相信大家对"怎么用C语言实现简易停车场管理系统"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

时间 车库 停车场 函数 车辆 结构 就是 汽车 类型 车场 车牌 系统 输入 简易 管理系统 语言 管理 只有 大门 字符 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 网络安全语言手抄报图片 手机软件开发和前端哪个好学 网络安全防范的具体措施 服务器安全日志很多登录 csgo网络正常连接服务器失败 互联网金融科技市场 如何评价网络安全零信任 在我的世界炸服务器违法吗 什么专业可以从事软件开发 软件开发规范目的 粉丝服务器介绍视频 管理打印服务器实验报告 数据库中如何打印期刊论文 网络安全在哪个行业最好 数据库的事务面试真题 杭州碳银互联网科技有限公司 上海宝互联网科技有限公司 怎么写软件开发公司优势 手机棋牌透视软件开发的条件 平顶山谷联网络技术有限 网络科技与互联网发展论文 数据库id如何重新设置 广州上广网络技术有限公司 服务器安全免责协议 扬州银联软件开发 数据库如何查询并修改 软件开发企业有哪些条件 数据库立讯 成都苹果手机软件开发如何收费 软件开发库管理员职责
0