<数据结构> rear指针指向队尾元素下一位置&&设置一个标志变量tag的循环队列实现(C语言)(第3种/共6种)

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#define MaxSize 5

typedef struct {
  int data[MaxSize];//此处tag本应为bool类型的变量 初始化tag为0
  int front,rear;  // tag==0表明循环队列初始化完成或上一次操作为出队操作
  int tag;        //  tag==1表明循环队列上一次操作为入队操作

}SqQueue;

int InitQueue(SqQueue*Q){
   Q->front=Q->rear=Q->tag=0;
   printf("该循环队列初始化完成\n\n");
}

int isEmpty(SqQueue Q){
   if(Q.front==Q.rear&&Q.tag==0)
      return 1;
   else
    return 0;

}

int length(SqQueue Q){//此处由于队空和队满时皆有Q.rear==Q.front 所以需要加一项tag是否为1来判断是队满还是队空
    if(Q.front!=Q.rear)
     return((Q.rear-Q.front+MaxSize)%MaxSize);
    else if(isEmpty(Q))
            return 0;
          else
            return MaxSize;

}

int EnQueue(SqQueue *Q,int e){
    if(Q->front==Q->rear&&Q->tag==1){
        printf("该循环队列已满 本次入队操作非法\n\n");
        return 0;

    }
    Q->data[Q->rear]=e;
    Q->rear=(Q->rear+1)%MaxSize;
    Q->tag=1;
    printf("本次入队元素:%d\n\n",e);
    return 1;



}

int DeQueue(SqQueue *Q,int *e){
    if(isEmpty(*Q)){
        printf("该循环队列为空 本次出队操作非法\n\n");
        return 0;

    }
    *e=Q->data[Q->front];
    Q->front=(Q->front+1)%MaxSize;
    Q->tag=0;
    printf("本次出队元素:%d\n\n",*e);
    return 0;

}

int GetHead(SqQueue Q){
    if(isEmpty(Q)){
        printf("该循环队列为空 本次查对头元素操作非法\n\n");
        return 0;
    }
    printf("循环队列当前对头元素为:%d\n\n",Q.data[Q.front]);
    return Q.data[Q.front];

}

int main(){
 SqQueue Q;
 int discard;
 InitQueue(&Q);
 DeQueue(&Q,&discard);
 if(isEmpty(Q))
        printf("当前该循环队列为空\n\n");
 else
        printf("当前该循环队列的长度为%d\n\n",length(Q));

 EnQueue(&Q,9);
 EnQueue(&Q,9);
 EnQueue(&Q,5);
 EnQueue(&Q,2);
 EnQueue(&Q,7);
 EnQueue(&Q,7);

 if(isEmpty(Q))
        printf("当前该循环队列为空\n\n");
    else
        printf("当前该循环队列的长度为%d\n\n",length(Q));
 DeQueue(&Q,&discard);

 if(isEmpty(Q))
        printf("当前该循环队列为空\n\n");
    else
        printf("当前该循环队列的长度为%d\n\n",length(Q));
 GetHead(Q);

 return 1;
}
  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

巴巴_羊

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

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

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

打赏作者

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

抵扣说明:

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

余额充值