环形队列

本文详细介绍了一种基于数组的循环队列数据结构的实现方法,包括初始化、销毁、判断是否为空、入队、出队及获取队列长度等基本操作,并通过C语言代码示例展示了整个过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <stdio.h>
#include <malloc.h>
#define MaxSize 100
typedef char ElemType;
typedef struct
{
	ElemType data[MaxSize];				//数据域
	int front,rear;	//指针域
} SqQueue;						//链栈类型定义
void InitQueue(SqQueue *&q)
{
	q=(SqQueue *)malloc(sizeof(SqQueue));
	q->front=q->rear=0;
}
void DestoryQueue(SqQueue *&q)
{
	free(q);
}
int QueueEmpty(SqQueue *q)
{
	return(q->front==q->rear);
}
int enQueue(SqQueue *&q,ElemType e)
{
    if((q->rear+1)%MaxSize==q->front)
        return 0;
        q->rear=(q->rear+1)%MaxSize;
        q->data[q->rear]=e;
        return 1;
}
int deQueue(SqQueue *&q,ElemType &e)
{

    if(q->rear==q->front)
        return 0;
    q->front=(q->front+1)%MaxSize;
    e=q->data[q->front];
    return 1;
}
int countQueue(SqQueue *&q)
{
    return((q->rear-q->front+MaxSize)%MaxSize);
}
int main()
{
    SqQueue *q;
    ElemType e;
    printf("(1)初始化队列q\n");
    InitQueue(q);
    printf("(2)队为:%s\n",(QueueEmpty(q)?"空":"非空"));
    printf("(3)依次进队元素a,b,c");
    enQueue(q,'a');
    enQueue(q,'b');
    enQueue(q,'c');
    printf("\n(4)出队一个元素:");
    deQueue(q,e);
    printf("%c",e);
    printf("\n(5)q队中元数个数:%d", countQueue(q));
    printf("\n(6)再依次进队元素d,e,f");
    enQueue(q,'d');
    enQueue(q,'e');
    enQueue(q,'f');
    printf("\n(7)q队中元数个数:%d", countQueue(q));
    printf("\n(8)出队全部元素:");
    while(!QueueEmpty(q))
    {
        deQueue(q,e);
        printf("%c",e);
    }
    printf("\n(9)销毁队列");
    DestoryQueue(q);
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值