实验一 -2-3:利用顺序栈及环形队列编写停车场管理程序

本文详细介绍了如何使用顺序栈和环形队列设计一个停车场管理程序,包括车辆进出的栈和队列操作、费用计算、内存管理以及主函数的实现。通过实际步骤和源码展示了解决问题的全过程。
摘要由CSDN通过智能技术生成

利用顺序栈及环形队列编写停车场管理程序

目录

利用顺序栈及环形队列编写停车场管理程序

一、实验步骤

二、运行结果

三、附录源码


一、实验步骤

设计思想:

本停车场管理程序的设计思想是使用顺序栈和环形队列来实现车辆的进出和收费管理。顺序栈用于存储停车场的空车位,以便快速找到可用的车位;环形队列用于存储进入停车场的车辆信息,包括车牌号、进场时间、停车费用等。通过进栈和出队操作来实现车辆的进出管理,通过计算停车时间和费用来实现收费管理。

算法描述:

1.定义车辆信息结构体,包括车牌号、进场时间、停车费用等字段。
2.定义停车场结构体,包括空车位栈和车辆队列。
3.初始化停车场,清空空车位栈和车辆队列。
4.车辆进入停车场时,将车辆信息加入车辆队列中,同时将一个空车位加入空车位栈中。
5.车辆离开停车场时,从车辆队列中弹出车辆信息,同时从空车位栈中弹出一个空车位。
6.计算车辆的停车时间和费用,根据收费标准计算出车辆的收费金额。
7.输出车辆的出场时间、停车费用和收费金额。
8.释放停车场所占用的内存空间。
开发流程:

1.定义车辆信息和停车场结构体。
2.实现初始化停车场函数。
3.实现车辆进入停车场函数,包括进队和进栈操作。
4.实现车辆离开停车场函数,包括出队和出栈操作。
5.实现计算停车时间和费用的函数。
6.实现输出车辆信息的函数。
7.在主函数中调用以上函数,完成停车场管理程序的操作和功能测试。
8.编译并运行程序,检查输出结果是否符合预期。

二、运行结果

三、附录源码

#include<stdio.h>
#include<malloc.h>
#define N 3 //停车场内最多的停车数
#define M 4 //候车场内最多的停车数
#define Price 2 //每单位停车费用
typedef struct
{
	int CarNo[N]; //车牌号
	int CarTime[N]; //进场时间
	int top; //栈指针
}SqStack; //声明顺序栈类型

typedef struct
{
	int CarNo[M]; //车牌号
	int front, rear; //队首和队尾指针
}SqQueue; //声明环形队列类型

//以下为栈的运算算法
void InitStack(SqStack* &s) //初始化栈
{
	s = (SqStack*)malloc(sizeof(SqStack));
	s->top = -1;
}

bool StackEmpty(SqStack* s) //判断栈空
{
	return s->top == - 1;
}

bool StackFull(SqStack* s) //判断栈满
{
	return s->top == N - 1;
}

bool Push(SqStack*& s, int e1, int e2) //进栈
{
	if (s->top == N - 1) return false; //栈满
	s->top++;
	s->CarNo[s->top] = e1;
	s->CarTime[s->top] = e2;
	return true;
}

bool Pop(SqStack*& s, int& e1, int& e2) //出栈
{
	if (s->top == -1) return false; //栈空
	e1 = s->CarNo[s->top];
	e2 = s->CarTime[s->top];
	s->top--;
	return true;
}

void DispStack(SqStack* s) //显示栈中元素
{
	for (int i = s->top; i >= 0; i--) printf("%d ", s->CarNo[i]);
	printf("\n");
}

//以下为队列的运算算法
void InitQueue(SqQueue*& q) //初始化队
{
	q = (SqQueue*)malloc(sizeof(SqQueue));
	q->front = q->rear = 0;
}

bool QueueEmpty(SqQueue *q) //判断队空
{
	return(q->front == q->rear);
}

bool QueueFull(SqQueue* q) //判断队满
{
	return (q->rear + 1) % M == q->front;
}

bool enQueue(SqQueue*& q, int e) //进队
{
	if ((q->rear + 1) % M == q->front) return false; //队满
	q->rear = (q->rear + 1) % M;
	q->CarNo[q->rear] = e;
	return true;
}

bool deQueue(SqQueue*& q, int& e) //出队
{
	if (q->front == q->rear) return false; //队空的情况
	q->front = (q->front + 1) % M;
	e = q->CarNo[q->front];
	return true;
}

void DispQueue(SqQueue* q) //显示队中元素
{
	int i = (q->front + 1) % M;
	printf("%d ", q->CarNo[i]);
	while ((q->rear - i + M) % M > 0)
	{
		i = (i + 1) % M;
		printf("%d ", q->CarNo[i]);
	}
	printf("\n");
}

int main()
{
	int comm, i, j;
	int no, e1, time, e2;
	SqStack* St, * St1;
	SqQueue* Qu;
	InitStack(St);
	InitStack(St1);
	InitQueue(Qu);
	do
	{
		printf(">输人指令(1:到达 2:离开 3:停车场 4:候车场 0:退出):");
		scanf("%d", &comm);
		switch (comm)
		{
		case 1: //汽车到达
			printf(" 车号 到达时间:");
			scanf("%d%d", &no, &time);
			if (!StackFull(St)) //停车场不满
			{
				Push(St, no, time);
				printf(" 停车场位置:%d\n", St->top + 1);
			}
			else //停车场满
			{
				if (!QueueFull(Qu)) //侯车场不满
				{
					enQueue(Qu, no);
					printf(" 候车场位置:%d\n", Qu->rear);
				}
				else printf(" 候车场已满,不能停车\n");
			}
			break;
		case 2:
			printf(" 车号 离开时间:");
			scanf("%d %d", &no, &time);
			for (i = 0; i <= St->top && St->CarNo[i] != no; i++);
			if (i > St->top) printf(" 未找到该编号的汽车\n");
			else
			{
				for (j = i; j <= St->top; j++)
				{
					Pop(St, e1, e2);
					Push(St1, e1, e2); //倒车到临时栈S1中
				}
				Pop(St, e1, e2);//该汽车离开
				printf(" %d汽车停车费用:%d\n", no, (time - e2) * Price);
				while (!StackEmpty(St1)) //将临时栈St1重新回到St中
				{
					Pop(St1, e1, e2);
					Push(St, e1, e2);
				}
				if (!QueueEmpty(Qu)) //队不空时, 将队头进栈St
				{
					deQueue(Qu, e1);
					Push(St, e1, time); //以当前时间开始计费
				}
			}
			break;
		case 3: //显示停车场情况
			if (!StackEmpty(St))
			{
				printf(" 停车场中的车辆:"); //输出停车场中的车辆
				DispStack(St);
			}
			else printf(" 停车场中无车辆\n");
			break;
		case 4: //显示候车场情况
			if (!QueueEmpty(Qu))
			{
				printf(" 候车场中的车辆:"); //输出候车场中的车辆
				DispQueue(Qu);
			}
			else printf(" 候车场中无车辆\n");
			break;
		case 0: //结束
			if (!StackEmpty(St))
			{
				printf(" 停车场中的车辆:"); //输出停车场中的车辆
				DispStack(St);
			}
			if (!QueueEmpty(Qu))
			{
				printf(" 候车场中的车辆:"); //输出候车场中的车辆
				DispQueue(Qu);
			}
			break;
		default: //其他情况
			printf(" 输入的命令错误\n");
			break;
		}
	} while (comm != 0);
		return 0;
}

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

噗-噗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值