typedef struct QUEUE
{
int * pBase;
int front;//头
int rear;//尾
int len;
}Queue;
//初始化
void init_queue(Queue *queue,int len);
//入队
void en_queue(Queue *queue,int data);
//出队
void out_queue(Queue *queue,int *pData);
//遍历
void traverse_queue(Queue *queue);
//是否是满的
bool full_queue(Queue * queue);
//是否是空
bool empty_queue(Queue *queue);
int main(int argc, const char * argv[]) {
Queue queue;
init_queue(&queue, 6);
en_queue(&queue, 1);
en_queue(&queue, 2);
en_queue(&queue, 3);
out_queue(&queue, NULL);
out_queue(&queue, NULL);
en_queue(&queue, 4);
en_queue(&queue, 5);
en_queue(&queue, 6);
traverse_queue(&queue);
return 0;
}
//初始化
void init_queue(Queue *queue,int len)
{
queue->pBase = (int *)malloc(sizeof(int) * len);
queue->front = 0;
queue->rear = 0;
queue->len = len;
}
//入队
void en_queue(Queue *queue,int data)
{
if (full_queue(queue)) {
printf("队列已满");
return;
}else
{
queue->pBase[queue->rear] = data;
queue->rear = (queue->rear + 1) % queue->len;
}
}
//遍历
void traverse_queue(Queue *queue)
{
int i = queue->front;
while (queue->rear != i) {
printf("%d ",queue->pBase[i]);
i = (i + 1) % queue->len;
}
}
//是否是满的
bool full_queue(Queue * queue)
{
if ((queue->rear + 1) % queue->len == queue->front) {
return true;
}else
{
return false;
}
}
//出队
void out_queue(Queue *queue,int *pData)
{
if (empty_queue(queue)) {
printf("队列为空");
return;
}else
{
if (pData != NULL) {
*pData = queue->front;
}
queue->front = (queue->front + 1) % queue->len;
}
}
//是否是空
bool empty_queue(Queue *queue)
{
if (queue->front == queue->rear) {
return true;
}else
{
return false;
}
}
循环队列
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 周末在家花了半天时间写了一个简单的双向循环链表,为什么要这样做,一是想比较一下Python原生的list和双向链表...
- 静态循环队列几个问题 1.静态队列为什么必须是循环队列? 因为不管是入队还是出队,front和rear都是增长的,...
- 我们知道队列这种数据结构的物理实现方式主要还是两种,一种是链队列(自定义节点类),另一种则是使用数组实现,两者各有...