文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言实现简单的停车场管理系统

2024-04-02 19:55

关注

本文实例为大家分享了C语言实现简单停车场管理系统的具体代码,供大家参考,具体内容如下

1.问题描述

1)有一个两层的停车场,每层有6个车位,当第一层车位停满后才允 许使用第二层(停车场可用一个二维数组实现),每辆车的信息包括车牌号,层号,车位号,停车时间共四项,其中停车时间按分钟计算;
2)假设停车场初始状态为第一层空、第二层已经有四辆车,其车位号依次为第二层的1-4号,停车时间依次为20,15,10,5;
3)停车操作:当一辆车进入停车场时,先输入其车牌号,再为它分配一个层号和一个车位号(分配前先查询车位的使用情况,如果第一层有空位则必须停在第一层),停车时间设为5,并将在此之前的停车时间加5。(此题简化时间的处理:当有一辆车进入时才对别的车加时间5分钟);
4)收费管理(取车):当有车开走时,输入其车牌号,先按其停车时间计算费用,每5分钟0.2元,同时将该车对应的车位设置为可使用状态。
5)输出停车场中全部车辆的信息;
6)退出系统;

涉及的知识

结构体的运用,用数组当函数参数等。

2.上代码

#include "stdio.h"
#include<string.h>
struct car
{
    char car_num[10];
    int floor;
    int position_num;
    int time;
}CAR[12] = { {"0",1,1,0},{"0",1,2,0},{"0",1,3,0},{"0",1,4,0},{"0",1,5,0},{"0",1,6,0}
            ,{"冀F12345",2,1,20},{"冀F17845",2,2,15},{"冀F12856",2,3,10},{"冀F12445",2,4,5},{ "0",2,5,0 }, {"0",2,6,0} };
void park(struct car CAR[])
{
    int i, j,k;
    int flag = 0;
    char carn[10];
    printf("\n请输入车牌号\n");
    scanf("%s", carn);
    for (k = 0; k < 12; k++)
    {
        if (strcmp(CAR[k].car_num, carn) == 0)
        {
            printf("该车已在停车场内\n");
            flag = 2;
            break;
        }
    }
    for (i = 0; i < 12; i++)
    {
        if (strcmp(CAR[i].car_num,"0") == 0&&flag==0)
        {
            strcpy(CAR[i].car_num, carn);
            for (j = 0; j < 12; j++)
            {
                if (strcmp(CAR[j].car_num, "0") != 0)
                {
                    CAR[j].time += 5;
                }
            }
            printf("该车可停在了%d层%d号\n", CAR[i].floor, CAR[i].position_num);
            flag = 1;
            break;
        }
    }
    if (flag == 0)
    {
        printf("\n停车场已满\n");
    }

}
void leave(struct car CAR[])
{
    int i, j;
    int flag = 0;
    char carn[10];
    float price;
    scanf("%s",carn);
    for (i = 0; i < 12; i++)
    {
        if (strcmp(CAR[i].car_num,carn)==0)
        {
            strcpy(CAR[i].car_num,"0");
            price = CAR[i].time*0.04;
            CAR[i].time = 0;
            flag = 1;
            printf("\n停车费%f\n", price);
        }
    }
    if (flag == 0)
    {
        printf("\n停车场内无此车\n");
    }
    
}
void information(struct car CAR[])
{
    printf("车牌号    \t层号\t位号\t时间\n");
    for (int i = 0; i < 12; i++)
    {
        printf("%-10s\t%d\t%d\t%d\n", CAR[i].car_num, CAR[i].floor, CAR[i].position_num, CAR[i].time);
    }

}
int main()
{
    int n;
    int m = -1;
    while (m != 0)
    {
        printf("\n*************************\n");
        printf("1.停车\n");
        printf("2.离开\n");
        printf("3.输出停车场信息\n");
        printf("0.退出\n");
        printf("*************************\n");
        printf("请输入功能号0-3:");
        scanf("%d", &m);
        while (m < 0 || m>3)
        {
            printf("\n输入错误!请输入正确的功能号0-3:");
            scanf("%d", &m);
        }
        if (m == 1)
            park(CAR);
        else if (m == 2)
            leave(CAR);
        else if (m == 3)
            information(CAR);
    }
    return 0;
}

3.运行结果部分截图

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯