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

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

typedef struct {
   int data[MaxSize];
   int front,rear,size;

}SqQueue;

int InitQueue(SqQueue *Q)//此种实现不需要牺牲一个存储位置
{                        //同时队空和队满时皆有:(Q.rear+1)%MaxSize==Q.front
   Q->rear=MaxSize-1;    //方便起见判空和判满时是使用Q.size
   printf("该循环队列已完成初始化\n\n");
   return 1;

}

int length(SqQueue Q){


      return(Q.size);

}

int isEmpty(SqQueue Q){
   if(Q.size==0&&(Q.rear+1)%MaxSize==Q.front)
      return 1;
   else
      return 0;

}

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

    }
    Q->rear=(Q->rear+1)%MaxSize;
    Q->data[Q->rear]=e;
    Q->size++;
     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->size--;
    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);


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

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

  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;


}

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
以下是使用C语言实现循环队列生成杨辉三角的代码: ```c #include <stdio.h> #include <stdlib.h> #define MAX_SIZE 100 // 定义循环队列 typedef struct { int front; // 队首指针 int rear; // 队尾指针 int items[MAX_SIZE]; // 队列元素 } Queue; // 初始化队列 void init_queue(Queue *q) { q->front = q->rear = 0; } // 判断队列是否为空 int is_empty(Queue *q) { return q->front == q->rear; } // 判断队列是否已满 int is_full(Queue *q) { return (q->rear + 1) % MAX_SIZE == q->front; } // 元素入队 void enqueue(Queue *q, int item) { if (!is_full(q)) { q->items[q->rear] = item; q->rear = (q->rear + 1) % MAX_SIZE; } } // 元素出队 int dequeue(Queue *q) { if (!is_empty(q)) { int item = q->items[q->front]; q->front = (q->front + 1) % MAX_SIZE; return item; } return -1; } // 生成杨辉三角 void generate_yanghui_triangle(int n) { Queue q; init_queue(&q); enqueue(&q, 1); // 第一行只有一个数字1 for (int i = 0; i < n; i++) { for (int j = 0; j <= i; j++) { printf("%d ", q.items[j]); } printf("\n"); for (int j = 0; j <= i; j++) { enqueue(&q, dequeue(&q) + q.items[j]); } enqueue(&q, 1); // 行末添加数字1 } } int main() { generate_yanghui_triangle(5); // 生成5行杨辉三角 return 0; } ``` 代码中定义了一个循环队列结构体Queue,包含front、rear和items三个成员变量。init_queue函数用于初始化队列,is_empty和is_full函数用于判断队列是否为空和已满,enqueue和dequeue函数实现元素的入队和出队操作。generate_yanghui_triangle函数使用队列来生成杨辉三角,通过两个for循环遍历队列中的数字并输出,将队首出队并加上队列中的每个数字,将结果入队,最后再将数字1入队。重复这个过程,就可以生成指定行数的杨辉三角。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

巴巴_羊

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

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

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

打赏作者

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

抵扣说明:

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

余额充值