队列的一些操作(线性表,链式)

#include <stdio.h>
#define MAX_STACK_SIZE 100
#define ERROR 0
#define OK 1
typedef int ElemType;
typedef int Status;
#define MAX_QUEUE_SIZE 100
typedef struct queue
{
    ElemType Queue_array[MAX_QUEUE_SIZE];
    int front;
    int rear;
}SqQueue;
// 设立一个队首指针front,一个队尾指针rear,分 别指向队首和队尾元素
//循环队列
//循环队列的初始化
SqQueue Init_CirQueue(void)
{
    SqQueue Q;;
    Q.front = Q.rear = 0;
    return (Q);
}
//入队操作(将数据元素e插入到循环队列Q的队尾
Status Insert_CirQueue(SqQueue Q,ElemType e)
{
    if((Q.rear+1)%MAX_QUEUE_SIZE == Q.front)
                return ERROR;
    Q.Queue_array[Q.rear] = e;
    Q.rear = (Q.rear+1)%MAX_QUEUE_SIZE;
    return OK;
}
//出对操作(将循环队列Q的对首元素出队
Status Delete_CirQueue(SqQueue Q,ElemType *x)
{
    if(Q.front+1 == Q.rear)
        return ERROR;
        *x = Q.Queue_array[Q.front];
        Q.front = (Q.front+1)%MAX_QUEUE_SIZE;
        return OK;
}
//链队运算及指针变化
//定义
//数据元素结点的定义
typedef struct Qnode
{
    ElemType data;
    struct Qnode *next;
}QNode;
typedef struct link_queue
{
    QNode *front,*rear;
}Link_Queue;
//链队的初始化
Link_Queue *Init_LinkQueue(void)
{
    Link_Queue *Q;
    QNode *p;
    p = (QNode *)malloc(sizeof(QNode));
    p ->next=NULL;
    Q = (Link_Queue *)malloc(sizeof(Link_Queue));
    Q->front = Q->rear = p;
    return (Q);
}
//链队列的入队操作,将数据元素e插入到链队列Q的队尾
Status Link_Insert_CirQueue(Link_Queue *Q,ElemType e)
{
    QNode *p;
    p = (QNode *)malloc(sizeof(QNode));
    if(!p)
        return ERROR;
    p->data;
    p->next=NULL;
    Q->rear->next = p->next;
    Q->rear = p;
    return OK;
}
//链的队列的出队操作
Status LInk_Delete_CirQueue(Link_Queue *Q,ElemType *x)
{
    QNode *p;
    if(Q->front == Q->rear)
        return ERROR;//队空
    p = Q->front->next;
    *x = p->data;
    Q->front->next = p->next;
    if(p == Q->rear)
        Q->rear = Q->front;
    free(p);
    return OK;
}
//链队列的撤销将链队列Q的队首元素出队
void Destroy_LinkQueue(Link_Queue *Q)
{
    while(Q->front!= NULL)
    {
        Q->rear = Q->front->next;
        free(Q->front);
        Q->front = Q->rear;
    }
}
int main()
{

}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值