队列的顺序存储结构实现

/* sq_queue.c
 *
 * Copyright (c) 2020
 * Author: plant
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 */

#include <stdio.h>

#define MAX_QUEUE_SIZE (100)
typedef int ELEM_TYPE;

typedef struct _sq_queue
{
	ELEM_TYPE data[MAX_QUEUE_SIZE];
	int front;
	int rear;
} sq_queue;

void sq_queue_init(sq_queue* queue)
{
	queue->front = 0;
	queue->rear = 0;
	return;
}

int sq_queue_length(const sq_queue queue)
{
	return (MAX_QUEUE_SIZE - queue.front + queue.rear) % MAX_QUEUE_SIZE;
}

int sq_queue_en(sq_queue* queue, const ELEM_TYPE elem)
{
	if ((queue->rear + 1) % MAX_QUEUE_SIZE == queue->front) return 0;
	queue->data[queue->rear] = elem;
	queue->rear = (queue->rear + 1) % MAX_QUEUE_SIZE;
	return 1;
}

int sq_queue_de(sq_queue* queue, ELEM_TYPE* elem)
{
	if (queue->front == queue->rear) return 0;
	*elem = queue->data[queue->front];
	queue->front = (queue->front + 1) % MAX_QUEUE_SIZE;
	return 1;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值