循环队列c语言版

一、循环队列结构体

复制代码
typedef int  QueueDataType; 
#define CQ_MAX_SIZE  10

typedef struct CircularQueue
{
   QueueDataType data[CQ_MAX_SIZE];
   
   /**标记队列首*/
   QueueDataType head;

   /**标记队列尾部*/
   QueueDataType rear;

} CircularQueue;

二、循环队列操作函数声明

复制代码
/**创建队列*/
CircularQueue* create_circular_queue();

/**队列是否已满*/
bool  isFull(CircularQueue* queue);

/**队列是否为空*/
bool  isEmpty(CircularQueue* queue);


/**入队列*/
bool  enqueue(CircularQueue* queue,QueueDataType el);


/**出队列*/
QueueDataType dequeue(CircularQueue* queue);


/**输出队列*/
void show_queue(CircularQueue* queue);

/**销毁队列*/
void   destory_queue(CircularQueue* queue);

三、循环队列操作函数定义

复制代码
/**创建队列*/
CircularQueue* create_circular_queue()
{
   CircularQueue* queue = (CircularQueue*) malloc(sizeof(CircularQueue));
   if(queue ==  NULL)
   {
    perror("CircularQueue分配内存空间失败");
    return NULL;
   }
   queue->head  = 0;
   queue->rear  = 0;
   return queue;
}

/**队列是否为空*/
bool  isEmpty(CircularQueue* queue)
{
  return queue->head == queue->rear;
}

/**队列是否已满*/
bool  isFull(CircularQueue* queue)
{
 //  rear是冗余出来的一个空间,置于队尾,用于记当前队中元素的个数
  return  (queue->rear + 1)%CQ_MAX_SIZE == queue->head;
}

/**入队列*/
bool  enqueue(CircularQueue* queue,QueueDataType el)
{
    if(isFull(queue))
    {
        perror("队列已满");
        return  false;
    }
    queue->data[queue->rear%CQ_MAX_SIZE]  = el ;
    queue->rear++;
    return true;
}


/**出队列*/
QueueDataType dequeue(CircularQueue* queue)
{
    if(isEmpty(queue))
    {
      perror("对列中暂无元素");
      return -1;
    }
    QueueDataType el = queue->data[queue->head%CQ_MAX_SIZE];
    queue->head++;
    return el;
}


/**输出队列*/
void show_queue(CircularQueue* queue)
{
    if(isEmpty(queue))
    {
      perror("对列中暂无元素");
      return ;
    }
    int i =  queue->head;
    while ( i < queue->rear)
    {
       QueueDataType el = queue->data[i%CQ_MAX_SIZE];
       printf("el=%d\n",el); 
       i++;
    }
}


void   destory_queue(CircularQueue* queue)
{
    free(queue);
}

四、测试队列

复制代码
void  test_cricular_queue()
{
  CircularQueue *quque = create_circular_queue();
  QueueDataType arr[] =  {11,21,31,41,51,61,71,81,91,101};
  int  i = 0;
  for(;i<10;i++)
  {
     enqueue(quque,arr[i]);
  }
  show_queue(quque);
  QueueDataType  el = dequeue(quque);
  printf("取出队列元素el=%d\n",el);
  destory_queue(quque);
}

运行结果:

相关推荐
-许平安-8 小时前
MCP项目笔记九(插件 bacio-quote)
c++·笔记·ai·plugin·mcp
沉鱼.448 小时前
第十三届题目
c语言·c++·算法
liulilittle8 小时前
C++ 无锁编程:单停多发送场景高性能方案
服务器·开发语言·c++·高性能·无锁·原子
无限进步_9 小时前
【C++】巧用静态变量与构造函数:一种非常规的求和实现
开发语言·c++·git·算法·leetcode·github·visual studio
小超超爱学习99379 小时前
大数乘法,超级简单模板
开发语言·c++·算法
Ricardo-Yang9 小时前
SCNP语义分割边缘logits策略
数据结构·人工智能·python·深度学习·算法
soragui10 小时前
【Python】第 4 章:Python 数据结构实现
数据结构·windows·python
samroom10 小时前
【鸿蒙应用开发 Dev ECO Studio 5.0版本】从0到1!从无到有!最全!计算器------按钮动画、滑动退格、中缀表达式转后缀表达式、UI设计
数据结构·ui·华为·typescript·harmonyos·鸿蒙
xyx-3v10 小时前
qt创建新工程
开发语言·c++·qt
算法鑫探11 小时前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发