算法队列实验设计操作看这篇就够了

加油吧!!!

#include "stdio.h"
#include "malloc.h"
#define ERROR 0
#define OK 1
typedef  int datatype;
#define  MAXSIZE  50  //队列的最大容量
//定义队列的结构体
typedef  struct
{
	datatype data[MAXSIZE];
	 int front, rear;
}SeQueue;

//置空队
SeQueue* InitSqQueue()
{
	SeQueue* Q;
	Q = (SeQueue*)malloc(sizeof(SeQueue));
	if (!Q)
		return NULL;
	else
	{
		Q->front = Q->rear = 0;
		return Q;
	}
}

//进栈初始化
void AssignQueue(SeQueue* Q)
{
	int i ,length;
	printf("请输入队列初始长度:\n");
	scanf_s("%d",&length);
	printf("输入的元素是:");
	for (i = 0; i < length; i++)
	{
		scanf_s("%d",&Q->data[i]);
		Q->rear = (Q->rear+1)%MAXSIZE;
	}
	
}


//入队
int EnQuenue(SeQueue* Q, datatype x)
{
	if ((Q->rear + 1) % MAXSIZE == Q->front)
	{ 
		printf("队列已满,无法实现入队操作\n"); 
	    return ERROR;
	}
	else
	{
		Q->data[Q->rear] = x;
		Q->rear = (Q->rear + 1) % MAXSIZE;
		printf("入队成功\n");
		return OK;
	}
}
//出队
int DeQueue(SeQueue* Q, datatype* x)
{
	SeQueue* q;
	*x = Q->data[Q->front];
	Q->front = (Q->front + 1) % MAXSIZE; 
	printf("出队成功!出队的元素是:%d\n",*x);
	return OK;
}
//判队空
int EmqutyQueue(SeQueue *Q)
{
	if (Q->rear == Q->front)
	{
		printf("队列为空。无法实现出队");
		return 1;
	}
	else
		return 0;
}

void OutLine(SeQueue *Q)
{
	int i;
	if (EmqutyQueue(Q))
	{
		printf("栈空!!!\n");
	}
	i = Q->front;
	while (i != Q->rear)
	{
		printf("%d  ",Q->data[i++]);
		if (i == MAXSIZE)
			i = 0;
	}
	    printf("\n");
}


//显示队列

void main()
{
	SeQueue *Q;
	int j, k,m;
	datatype x;
	Q=InitSqQueue();
	do
	{
		printf("\n\n\n\n");
		printf("\t\t\t 队列子系统\n");
		printf("\t\t*******************************\n");	
		printf("\t\t*        1----初始化       *\n");
		printf("\t\t*        2----进 队 列     *\n");
		printf("\t\t*        3----出 队 列    *\n");
		printf("\t\t*        4----队列空否    *\n");
		printf("\t\t*        5----显示队列    *\n");
		printf("\t\t*        0----返  回    *\n");
		printf("\t\t*******************************\n");
		printf("\t\t 请选择菜单项(0-5):");
		scanf_s("%d", &k); getchar();
		switch (k)
		{
		case 0:
			k = 0;
			break;
		case 1:       //创建队列
			AssignQueue(Q);
			break;
		case 2:         //进队列
			printf("\n   请输入要进队列的数据:");
			scanf_s("%d",&x);
			EnQuenue( Q , x);
			OutLine(Q);
			break;
		case 3:          //出队列
			if (EmqutyQueue(Q) == 0)
			{
				DeQueue(Q, &m);
				printf("出栈的数字是%d\n", m);
				OutLine(Q);
			}
			break;
		case 4:          //判断队列空否 
			if (EmqutyQueue(Q))                     
				printf("此队列为空!!!");
			else printf("此队列不空。");
			break;
		case 5:       //显示队列
			OutLine(Q);
			break;
		}

	} while (k != 0);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值