【C语言】C语言 停车场管理系统的设计与实现(源码)【独一无二】

请添加图片描述


👉博__主👈:米码收割机
👉技__能👈:C++/Python语言
👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。


系列文章目录


目录

  • 系列文章目录
  • 一、设计要求
  • 二、设计思路
    • 1. 总体设计思路
    • 2. 数据结构设计
      • 2.1 定义车结构体(Car)
      • 2.2 定义停车场结构体(Stack)
      • 2.3 定义便道结构体(Queue)
    • 3. 模块说明与代码
      • 3.1 初始化模块
        • 3.1.1 初始化栈
        • 3.1.2 初始化队列
      • 3.2 判满/判空操作
        • 3.2.1 栈的判满与判空
        • 3.2.2 队列的判满与判空
      • 3.3 基本数据操作
        • 3.3.1 栈操作:入栈与出栈
        • 3.3.2 队列操作:入队与出队
      • 3.4 车辆到达处理模块
      • 3.5 车辆离开处理模块
      • 3.6 菜单与主函数
        • 3.6.1 显示菜单
        • 3.6.2 主函数
  • 三、可视化分析


一、设计要求

一、停车场管理系统的设计与实现
1设计要求
1.1问题描述(任务)
设有一个可以停放n辆汽车的狭长停车场,它只有一个大门可以供车辆进出。车辆按到达停车场时间的早晚依次从停车场最里面向大门口处停放(最先到达的第一辆车放在停车场的最里面)。如果停车场已放满n辆车,则后来的车辆只能在停车场大门外的便道上等待,一旦停车场内有车开走,则排以便道上的第一辆车就进入停车场。停车场内如有某辆车要开走,在它之后进入停车场的车都必须先退出停车场为它让路,待其开出停车场后,这些辆再依原来的次序进场。每辆车在离开停车场时,都应根据它在停车场内停留的时间长短交费。如果停留在便道上的车未进停车场时,允许其离去,不收停车费,并且仍然保持在便道上等待的车辆的次序。

1.2基本功能60~70分
要求程序输出每辆车到达后的停车位置(停车场或便道上),以及某辆车离开停车场应交纳的费用和它在停车场内停留的时间。

1.3建议拓展的功能20分
①系统功能以菜单方式显示
②车辆编号为字符型
③设置屏幕字体颜色
④单位时间收费值可以修改

在这里插入图片描述


二、设计思路

1. 总体设计思路

本系统模拟车辆进入停车场和在便道等待的管理情况,主要思想包括:

  • 数据结构选择

    • 用栈(Stack)来模拟停车场。停车场遵循先进后出(LIFO)原则,当车离开时,需要将后进车辆先弹出,才能找到目标车辆,然后再将中间车辆重新入栈。
    • 用循环队列(Queue)来模拟便道的等待队列。便道按照先进先出(FIFO)管理,等待车辆可以依次进入停车场。
  • 基本操作

    • 车辆到达:当车辆到达系统时,若停车场未满,则直接进入停车场;否则,车辆进入便道等待。
    • 车辆离开:车辆在离开停车场时,需要先从停车场中找到目标车辆,计算费用,并将临时存放的非目标车辆依次恢复入栈。同时,便道队列中的第一辆车会进入停车场。
    • 收费设置:系统支持修改每单位时间的收费标准。
  • 菜单驱动
    系统通过文本菜单与用户交互,用户可选择车辆到达、车辆离开、修改收费值及退出系统。

2. 数据结构设计

2.1 定义车结构体(Car)

车的基本信息包括车牌号、到达时间和离开时间。
代码如下:

typedef struct {
    char id[10];      // 车牌号
    int arrive_time;  // 到达时间
    int leave_time;   // 离开时间
} Car;

2.2 定义停车场结构体(Stack)

使用栈结构模拟停车场,数组保存车信息,top 表示栈顶指针。
代码如下:

#define MAX_CAR 10  // 定义停车场最大车位数

typedef struct {
    Car cars[MAX_CAR];
    int top;
} Stack;

在这里插入图片描述

2.3 定义便道结构体(Queue)

采用循环队列模拟便道。数组存放等待车辆,frontrear 分别为队头和队尾指针。
代码如下:

#define MAX_WAIT 10 // 定义便道最大等待车位数

typedef struct {
    Car cars[MAX_WAIT];
    int front;
    int rear;
} Queue;

3. 模块说明与代码

3.1 初始化模块

3.1.1 初始化栈

初始化时将 top 设为 -1,表示栈为空。

void initStack(Stack *s) {
    s->top = -1;
}
3.1.2 初始化队列

初始化队列时,将 frontrear 都设置为 0。

void initQueue(Queue *q) {
    q->front = q->rear = 0;
}

3.2 判满/判空操作

3.2.1 栈的判满与判空
  • 栈满判断:当 top 达到 MAX_CAR - 1 时,表示停车场已满
  • 栈空判断top 的值为 -1 时表示停车场为空
int isStackFull(Stack *s) {
    return s->top == MAX_CAR - 1;
}

int isStackEmpty(Stack *s) {
    return s->top == -1;
}
3.2.2 队列的判满与判空
  • 队列满判断:利用循环队列,当 (rear + 1) % MAX_WAIT == front 时,队列满
  • 队列空判断:当 rear == front 时,队列为空
int isQueueFull(Queue *q) {
    return (q->rear + 1) % MAX_WAIT == q->front;
}

int isQueueEmpty(Queue *q) {
    return q->rear == q->front;
}

在这里插入图片描述


3.3 基本数据操作

3.3.1 栈操作:入栈与出栈
  • 入栈:在栈不满时,将车辆数据存入数组并更新 top
  • 出栈:在栈不空时,从栈顶弹出车辆数据,并将 top 减 1
void pushStack(Stack *s, Car car) {
    if (isStackFull(s)) {
        printf("停车场已满\n");
        return;
    }
    s->cars[++s->top] = car;
}

Car popStack(Stack *s) {
    if (isStackEmpty(s)) {
        printf("停车场为空\n");
        Car empty_car = {"", -1, -1};
        return empty_car;
    }
    return s->cars[s->top--];
}
3.3.2 队列操作:入队与出队
  • 入队:在队列未满时,将车辆添加到 rear 处,并更新队尾
  • 出队:在队列非空时,从 front 处取出车辆,并更新队头
void enqueue(Queue *q, Car car) {
    if (isQueueFull(q)) {
        printf("便道已满\n");
        return;
    }
    q->cars[q->rear] = car;
    q->rear = (q->rear + 1) % MAX_WAIT;
}// 此处省略20行代码
    }
    Car car = q->cars[q->front];
    q->front = (q->front + 1) % MAX_WAIT;
    return car;
}

在这里插入图片描述

3.4 车辆到达处理模块

当车辆到达时,首先构造车辆记录(包括车牌、到达时间及初始化离开时间),然后判断停车场是否有空位:

  • 如果停车场满,则将车辆加入便道队列;
  • 否则直接入栈到停车场。
void carArrival(Stack *parking, Queue *waiting, char *id, int time) {
    Car car;
    strcpy(car.id, id);     // 设置车牌号
    car.arrive_time = time; // 设置到达时间
    car.leave_time = -1;    // 初始化离开时间

    if (isStackFull(parking)) {
        enqueue(waiting, car); // 停车场满,将车加入便道
        printf("车牌号%s的车停在便道上\n", id);
    } else {
        pushStack(parking, car); // 停车场未满,将车推入停车场
        printf("车牌号%s的车停在停车场内\n", id);
    }
}

3.5 车辆离开处理模块

当车辆离开时,需要从停车场中找到目标车辆,因此需要使用一个临时栈辅助:

  1. 从停车场栈中依次弹出车辆,直到找到目标车辆。
  2. 找到车辆后设置离开时间,并计算停车持续时间及费用。
  3. 将临时栈中暂时移出的车辆重新推入停车场,以保持原有顺序。
  4. 如果便道有等待车辆,则将便道队首的车辆进入停车场,并更新其到达时间为当前离开的时间。
void carDeparture(Stack *parking, Queue *waiting, char *id, int time, int fee_per_unit) {
    Stack temp_stack;
    initStack(&temp_stack); // 初始化临时栈
    Car car;
    int found = 0;

    // 从停车场中寻找要离开的车
    while (!isStackEmpty(parking)) {
        car = popStack(parking);
        if (strcmp(car.id, id) == 0) {
            found = 1;
            car.leave_time = time; // 设置离开时间
            break;
        // 此处省略20行代码
            printf("车牌号%s的车从便道进入停车场\n", next_car.id);
        }
    }
}

3.6 菜单与主函数

3.6.1 显示菜单

菜单函数将显示系统支持的操作选项,包括车辆到达、离开、修改收费值以及退出系统。

void displayMenu() {
    printf("\n停车场管理系统\n");
    printf("1. 车辆到达\n");
    printf("2. 车辆离开\n");
    printf("3. 修改收费值\n");
    printf("4. 退出系统\n");
    printf("请选择操作: ");
}
3.6.2 主函数

main() 函数中,首先初始化停车场和便道数据结构,然后进入菜单循环,根据用户选择调用相应模块,最后程序退出。

int main() {
    Stack parking;
    Queue waiting;
    initStack(&parking); // 初始化停车场栈
    initQueue(&waiting); // 初始化便道队列

    int fee_per_unit = 2;  // 每单位时间收费值
    int choice;
    char id[10];
    int time;

    // 主循环:显示菜单并处理用户选择
    while (1) {
        displayMenu();
        scanf("%d", &choice);

        switch (choice) {
            case 1:
                printf("请输入车牌号: ");
                scanf("%s", id); // 输入车牌号
                printf("请输入到达时间: ");
                // 此处省略20行代码
            default:
                printf("无效的选择,请重新输入\n");
        }
    }

    return 0;
}

在这里插入图片描述



三、可视化分析

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/969834.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【现代深度学习技术】深度学习计算 | GPU

【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈PyTorch深度学习 ⌋ ⌋ ⌋ 深度学习 (DL, Deep Learning) 特指基于深层神经网络模型和方法的机器学习。它是在统计机器学习、人工神经网络等算法模型基础上,结合当代大数据和大算力的发展而发展出来的。深度学习最重…

蓝桥杯备考:贪心算法之纪念品分组

P1094 [NOIP 2007 普及组] 纪念品分组 - 洛谷 这道题我们的贪心策略就是每次找出最大的和最小的&#xff0c;如果他们加起来不超过我们给的值&#xff0c;就分成一组&#xff0c;如果超过了&#xff0c;就把大的单独成一组&#xff0c;小的待定 #include <iostream> #i…

【Elasticsearch】Mapping概述

以下是Elasticsearch中提到的关于Mapping的各模块概述&#xff1a; --- 1.Dynamic mapping&#xff08;动态映射&#xff09; 动态映射是指Elasticsearch在索引文档时&#xff0c;自动检测字段类型并创建字段映射的过程。当你首次索引一个文档时&#xff0c;Elasticsearch会根…

java商城解决方案

数字化时代&#xff0c;电子商务已成为企业拓展市场的重要渠道。对于想要建立在线商店的企业来说&#xff0c;选择正确的技术堆栈至关重要。 Java作为一种成熟且广泛使用的编程语言&#xff0c;为构建购物中心提供了强大的功能和灵活性。 商城Java源码&#xff1a;商城开发的核…

SSM开发(十二) mybatis的动态SQL

目录 一、为什么需要动态SQL? Mybatis 动态 sql 是做什么的? 二、多种动态 SQL 元素 三、示例 1、model定义 2、数据库定义 3、UserMapper接口及UserMapper.xml内容定义 if标签 choose/when/otherwise 标签 foreach标签 trim 标签 四、动态SQL注意 一、为什么需…

HCIA项目实践---OSPF的知识和原理总结

9.5 OSPF 9.5.1 从哪些角度评判一个动态路由协议的好坏&#xff1f; &#xff08;1&#xff09;选路佳&#xff08;是否会出环&#xff09; OSPF 协议采用链路状态算法&#xff0c;通过收集网络拓扑信息来计算最短路径&#xff0c;从根本上避免了路由环路的产生。 &#xff08…

HCIA项目实践---OSPF的基本配置

9.5.12 OSPF的基本配置 &#xff08;所搭环境如上图所示&#xff09; A 先配置IP地址 (先进入路由器R1的0/0/0接口配置IP地址&#xff0c;再进入环回接口配置IP地址) &#xff08;配置R2路由器的0/0/0和0/0/1以及环回接口的IP地址&#xff09; &#xff08;置R3路由器的0/0/0接…

github上创建person access token

在 GitHub 上创建 Personal Access Token&#xff08;PAT&#xff09; 时&#xff0c;权限设置非常重要。正确的权限设置可以确保 Token 能够访问所需的资源&#xff0c;同时避免授予过多权限带来的安全风险。以下是详细的权限设置说明&#xff1a; 1. 进入 Token 创建页面 登录…

【网络编程】之Udp网络通信步骤

【网络编程】之Udp网络通信步骤 TCP网络通信TCP网络通信的步骤对于服务器端对于客户端 TCP实现echo功能代码实现服务器端getsockname函数介绍 客户端效果展示 对比两组函数 TCP网络通信 TCP网络通信的步骤 对于服务器端 创建监听套接字。&#xff08;调用socket函数&#xff…

【教程】MySQL数据库学习笔记(七)——多表操作(持续更新)

写在前面&#xff1a; 如果文章对你有帮助&#xff0c;记得点赞关注加收藏一波&#xff0c;利于以后需要的时候复习&#xff0c;多谢支持&#xff01; 【MySQL数据库学习】系列文章 第一章 《认识与环境搭建》 第二章 《数据类型》 第三章 《数据定义语言DDL》 第四章 《数据操…

国自然地区基金|影像组学联合病理组学预测进展期胃癌术后预后的研究|基金申请·25-02-13

小罗碎碎念 今天和大家分享一个国自然地区科学项目&#xff0c;执行年限为2020.01&#xff5e;2023.12&#xff0c;直接费用为34万元。 胃癌在我国发病形势严峻&#xff0c;现有TNM分期预后评估存在局限&#xff0c;难以满足精准医疗需求。本项目运用“医工结合&#xff0c;学科…

nvm下载安装教程(node.js 下载安装教程)

前言 nvm 官网地址&#xff1a;https://nvm.uihtm.com nvm 是一个 node.js 的版本管理工具&#xff0c;相比于仅安装 node.js&#xff0c;我们可以使用 nvm 直接下载或卸载 node.js&#xff0c;可以同时安装多个 node.js 版本&#xff0c;并动态的切换本地环境中的 node.js 环…

项目BUG

项目BUG 前言 我创作这篇博客的目的是记录学习技术过程中的笔记。希望通过分享自己的学习经历&#xff0c;能够帮助到那些对相关领域感兴趣或者正在学习的人们。 项目BUG 1.低频率信号(100k或 200K以下)可以直接用一根导线焊接出几根导线来分几路&#xff0c;高频率信号只能…

Apollo 9.0 速度动态规划决策算法 – path time heuristic optimizer

文章目录 1. 动态规划2. 采样3. 代价函数3.1 障碍物代价3.2 距离终点代价3.3 速度代价3.4 加速度代价3.5 jerk代价 4. 回溯 这一章将来讲解速度决策算法&#xff0c;也就是SPEED_HEURISTIC_OPTIMIZER task里面的内容。Apollo 9.0使用动态规划算法进行速度决策&#xff0c;从类名…

吴恩达深度学习——词嵌入

内容来自https://www.bilibili.com/video/BV1FT4y1E74V&#xff0c;仅为本人学习所用。 文章目录 词表特征词嵌入的类比推理嵌入矩阵词嵌入Word2Vec跳字模型模型细节负采样 GloVe词向量&#xff08;了解&#xff09; 情绪分类 词表特征 使用 one-hot 对词汇进行编码时&#x…

数据结构——Makefile、算法、排序(2025.2.13)

目录 一、Makefile 1.功能 2.基本语法和相关操作 &#xff08;1&#xff09;创建Makefile文件 &#xff08;2&#xff09;编译规则 &#xff08;3&#xff09;编译 &#xff08;4&#xff09;变量 ①系统变量 ②自定义变量 二、 算法 1.定义 2.算法的设计 &#xff…

达梦:TPCC 压测

目录 造数1. 脚本启动2. 检查数据库信息3. 删除旧用户和表空间4. 创建新的表空间5. 创建用户和表6. 数据加载7. 创建索引8. 创建存储过程和序列9. 检查数据空间使用情况10. 启用表的快速访问池11. 数据加载完成总结 压测1. 脚本启动2. 检查数据表空间3. 设置表的快速池标志4. 检…

2024 StoryDiffusion 文字/文字+图像----->视频

基于扩散模型的生成模型在生成长序列图像和视频时面临内容一致性的重大挑战&#xff0c;尤其是涉及复杂主题和细节的场景中&#xff0c;角色身份、服饰风格等元素难以保持连贯。传统方法通常依赖潜在空间的运动预测&#xff0c;但长视频生成时易出现不稳定性。针对这些问题&…

在带有Intel Arc GPU的Windows上安装IPEX-LLM

在带有Intel Arc GPU的Windows上安装IPEX-LLM 在带有Intel Arc GPU的Windows上安装IPEX-LLM先决条件安装 GPU 驱动安装 Visual Studio 2022 社区版安装 Intel oneAPI Base Toolkit安装 IPEX-LLM创建虚拟环境环境验证 可能遇到的问题 在带有Intel Arc GPU的Windows上安装IPEX-LL…

流程控制(if—elif—else,while , for ... in ...)

1. 流程控制 流程&#xff1a;计算机执行代码的顺序 流程控制&#xff1a;对计算机执行代码的顺序的管理 2. 流程控制分类 流程控制分类&#xff1a; 顺序流程&#xff1a;自上而下的执行结构&#xff0c;即 Python 默认流程 选择/分支流程&#xff1a;根据某一步的判断&am…