数组队列

#ifndef _ARRAY_QUEUE_H_
#define _ARRAY_QUEUE_H_

#define MAX_ARRAY_SIZE  100

#define QElemType int

typedef struct {
        QElemType *base;
        int front;
        int rear;
}SqQueue;

int initQueue(SqQueue *Q);

int queueLength(SqQueue *Q);

int enQueue(SqQueue *Q,QElemType e); 

int deQueue(SqQueue *Q,QElemType *e);

int destoryQueue(SqQueue *Q);                                                                                             

#endif
#include <stdio.h>                                                                                                        
#include <stdlib.h>

#include "array_queue.h"

int initQueue(SqQueue *Q){

        Q->base = (QElemType *)malloc(sizeof(QElemType) * MAX_ARRAY_SIZE);

        if(!(Q->base))
                return -1;

        Q->front = Q->rear = 0;

        return 0;
}

int destoryQueue(SqQueue *Q){

        if(Q->base)
                free(Q->base);

        return 0;
}

int queueLength(SqQueue *Q){

        return(Q->rear - Q->front + MAX_ARRAY_SIZE) % MAX_ARRAY_SIZE;
}


int enQueue(SqQueue *Q,QElemType e){

        if( (Q->rear + 1) % MAX_ARRAY_SIZE == Q->front )
                return -1;

        Q->base[Q->rear] = e;
        Q->rear = (Q->rear + 1) % MAX_ARRAY_SIZE;

        return 0;
}

int deQueue(SqQueue *Q,QElemType *e){

        if(Q->front == Q->rear)
                return -1;

        *e = Q->base[Q->front];

        Q->front = (Q->front + 1) % MAX_ARRAY_SIZE;

        return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值