线性表之循环队列

  • 规定:front指向队头元素的位置; rear指向队尾元素的下一个位置
  • 在队列操作过程中,为了提高效率,以调整指针代替队列元素的移动,并将数组作为循环队列的操作空间
  • 为区别空队和满队,牺牲一个存储单元,满队元素个数比数组元素个数少一个
latex 复制代码
初始状态(队列空):
front = 0, rear = 0
   [ ] [ ] [ ] [ ] [ ]
    0   1   2   3   4
插入 A, B, C:
front = 0, rear = 3
   [A] [B] [C] [ ] [ ]
    0   1   2   3   4
插入 D, E 后:
front = 0, rear = 0(绕回)
   [A] [B] [C] [D] [E]
    0   1   2   3   4

计算:(rear + 1) % N = (0 + 1) % 5 = 1
但 front = 0,所以不相等? 这里有问题...


如果队列将要满的状态(实际还有一个空位):
front = 0, rear = 4
   [A] [B] [C] [D] [ ]
    0   1   2   3   4

计算:(rear + 1) % N = (4 + 1) % 5 = 0
此时 front = 0,所以相等 → 判断为满
虽然索引4的位置是空的,但已经判断为满了!
  • 队列的定义:
c 复制代码
typedef  int  data_t ;    /*定义队列中数据元素的数据类型*/
#define  N  64	    	  /*定义队列的容量*/
typedef  struct {
      data_t  data[N] ;   /*用数组作为队列的储存空间*/
      int  front, rear ;     /*指示队头位置和队尾位置的指针*/
} sequeue_t ; 	     		/*顺序队列类型定义*/
c 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "sequeue.h"

sequeue * queue_create() {
	sequeue *sq;

	if ((sq = (sequeue *)malloc(sizeof(sequeue))) == NULL) {
		printf("malloc failed\n");
		return NULL;
	}

	memset(sq->data, 0, sizeof(sq->data));
	sq->front = sq->rear = 0;
	return sq;
}

int enqueue(sequeue *sq, datatype x) {
	if (sq == NULL) {
		printf("sq is NULL\n");
		return -1;
	}

	if ((sq->rear + 1) % N == sq->front) {
		printf("sequeue is full\n");
		return -1;
	}

	sq->data[sq->rear] = x;
	sq->rear = (sq->rear + 1) % N;

	return  0;
}

datatype dequeue(sequeue *sq) {
	datatype ret;

	ret = sq->data[sq->front];

	sq->front = (sq->front + 1) % N;

	return ret;
}

int queue_empty(sequeue *sq) {
	if (sq == NULL) {
		printf("sq is NULL\n");
		return -1;
	}

	return (sq->front == sq->rear ? 1 : 0);
}

int queue_full(sequeue *sq) {
	if (sq == NULL) {
		printf("sq is NULL\n");
		return -1;
	}

	if ((sq->rear + 1) % N == sq->front) {
		return 1;
	}
	else {
		return 0;
	}
}

int queue_clear(sequeue *sq) {
	if (sq == NULL) {
		printf("sq is NULL\n");
		return -1;
	}

	sq->front = sq->rear = 0;

	return 0;
}

sequeue * queue_free(sequeue *sq) {
	if (sq == NULL) {
		printf("sq is NULL\n");
		return NULL;
	}

	free(sq);
	sq = NULL;

	return NULL;
}
c 复制代码
typedef int datatype;
#define N 128

typedef struct {
	datatype data[N];
	int front;
	int rear;
}sequeue;

sequeue * queue_create();
int enqueue(sequeue *sq, datatype x);
datatype dequeue(sequeue *sq);
int queue_empty(sequeue *sq);
int queue_full(sequeue *sq); 
int queue_clear(sequeue *sq);
sequeue * queue_free(sequeue *sq);
c 复制代码
#include <stdio.h>
#include "sequeue.h"

int main(int argc, const char *argv[])
{
	sequeue *sq;

	if ((sq = queue_create()) == NULL) {
		return -1;
	}
	
	enqueue(sq, 10);
	enqueue(sq, 100);
	enqueue(sq, 1000);

	while (!queue_empty(sq)) {
		printf("dequeue:%d\n", dequeue(sq));
	}

	queue_free(sq);

	return 0;
}
相关推荐
流年如夢1 天前
排序算法详解
数据结构·算法·排序算法
z200509301 天前
今日算法(二叉树)
数据结构·c++·算法
故事和你911 天前
洛谷-【图论2-2】最短路1
开发语言·数据结构·c++·算法·动态规划·图论
Simple-Soft1 天前
指针的高级应用与技巧 - C语言的灵魂
c语言·数据结构·算法
Controller-Inversion2 天前
23. 合并 K 个升序链表
数据结构·链表
Mr_pyx2 天前
面试题记录
jvm·数据结构·算法·spring·mybatis
努力努力再努力wz2 天前
【C++高阶数据结构系列】:时间轮定时器详解:原理分析与代码实现,带你从零手撕时间轮!(附时间轮的实现源码)
c语言·开发语言·数据结构·c++·qt·算法·ui
iiiiyu2 天前
⾯向对象和集合编程题
java·大数据·开发语言·数据结构·编程语言
YuanDaima20482 天前
贪心算法基础原理与题目说明
数据结构·人工智能·python·算法·贪心算法·手撕代码