广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言课程设计之停车场管理问题
  • 580
分享到

C语言课程设计之停车场管理问题

2024-04-02 19:04:59 580人浏览 八月长安
摘要

C语言课程设计之停车场管理问题,供大家参考,具体内容如下 1.问题描述 停车场内只有一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,

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.

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

--结束END--

本文标题: C语言课程设计之停车场管理问题

本文链接: https://www.lsjlt.com/news/142859.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言课程设计之停车场管理问题
    C语言课程设计之停车场管理问题,供大家参考,具体内容如下 1.问题描述 停车场内只有一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,...
    99+
    2022-11-13
  • C语言实现宿舍管理课程设计
    本文实例为大家分享了C语言实现宿舍管理的具体代码,供大家参考,具体内容如下 和本编前几个程序结构差不多,比较简单直观,希望可以给你带来帮助。 #include <stdio.h...
    99+
    2022-11-13
  • C语言实现宾馆管理系统课程设计
    本文实例为大家分享了C语言实现宾馆管理系统的具体代码,供大家参考,具体内容如下 课程设计题目: 宾馆管理系统 一、需求分析 近年来,科技进步不仅促进了全球旅游企业的快速增长,而且指导...
    99+
    2022-11-13
  • C语言实现学籍管理系统课程设计
    本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下 学校的课程设计,自己完成后整理了一下。自己用链表实现的一个较简单的学籍管理系统,都是通过一些链表以及文...
    99+
    2022-11-13
  • C语言实现图书管理系统课程设计
    目录设计要求实现代码运行结果本文实例为大家分享了C语言实现图书管理系统的具体代码,供大家参考,具体内容如下 设计要求 设计图书管理系统 要求如下: 1.对书名,作者,编号,出版单位,...
    99+
    2022-11-13
  • C语言实现宿舍管理系统课程设计
    宿舍管理系统C语言源码,供大家参考,具体内容如下 内容摘要 学生宿舍管理系统时应对学生宿舍管理的现代化、网络化,逐步摆脱学生宿舍管理的人工管理方式,提高学生宿舍管理效率而开发的,它包...
    99+
    2022-11-13
  • C语言实现销售管理系统课程设计
    本文实例为大家分享了C语言实现销售管理系统的具体代码,供大家参考,具体内容如下 一.C程序设计课程设计题目简介 该设计要求学生以某公司销售管理业务为背景,设计、开发一套“...
    99+
    2022-11-13
  • C语言实现电话簿管理系统课程设计
    本文实例为大家分享了C语言课程设计:电话簿管理系统,供大家参考,具体内容如下 文件目录: 初始界面 现在显示一部分代码: //添加联系人 void add() { i...
    99+
    2022-11-12
  • C语言实现酒店客房管理系统课程设计
    本文实例为大家分享了C语言实现酒店客房管理系统的具体代码,供大家参考,具体内容如下 设计目标:设计一个酒店客房管理系统,用C语言实现。对该系统的要求如下: 一、需求描述 系统角色: ...
    99+
    2022-11-13
  • C语言实现学生学籍管理系统课程设计
    目录设计要求完整代码运行结果本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 设计要求 设计学籍管理系统 1、添加学生信息2、浏览学生信息3、查询学...
    99+
    2022-11-13
  • C语言实现学生成绩管理系统课程设计
    目录设计要求完整代码运行结果本文实例为大家分享了C语言实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 设计要求 设计学生成绩管理系统 要求如下: 1.输入学生信息2.统计学...
    99+
    2022-11-13
  • C语言实现超市信息管理系统课程设计
    本文实例为大家分享了C语言实现超市信息管理系统的具体代码,供大家参考,具体内容如下 一、 需求分析 目前商品市场的商品信息玲琅满目,货物信息的储存以及更新就变的越来越重要。因此,我们...
    99+
    2022-11-13
  • C语言实现学生宿舍信息管理系统课程设计
    本文实例为大家分享了C语言实现学生宿舍信息管理系统的具体代码,供大家参考,具体内容如下 一、问题陈述 宿舍对于大学生在校生活来说相当于家的存在,而宿舍管理又是学校后勤管理的重要环节,...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作