线性表之队列

  • 队列是限制在两端进行插入操作和删除操作的线性表
  • 允许进行存入操作的一端称为"队尾"允许进行删除操作的一端称为"队头"
  • 当线性表中没有元素时,称为"空队"
  • 特点 :先进先出(FIFO)或后进后出
  • 普通队列的缺点:
    • 出队后前面的空间无法重用,会造成"假溢出"
    • 当 sq->front > 0 且 sq->rear == N 时,虽然数组前面有空位,但队列已满
  • 在实际应用中,循环队列是更高效的选择,因为它避免了元素的移动,空间利用率更高。
  • 普通队列的主要缺点是空间浪费或需要移动元素的开销
  • 功能实现
c 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.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 == N) {
        printf("sequeue is full\n");
        return -1;
    }
    
    sq->data[sq->rear] = x;
    sq->rear++;
    
    return 0;
}

datatype dequeue(sequeue *sq) {
    datatype ret;
    
    if (sq == NULL || sq->front == sq->rear) {
        printf("queue is empty or NULL\n");
        return (datatype)-1;  
    }
    
    ret = sq->data[sq->front];
    
    sq->front++;
    
    // 可选:当队列为空时,重置指针以重用空间
    if (sq->front == sq->rear) {
        sq->front = sq->rear = 0;
    }
    
    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;
    }
    
    return (sq->rear == N ? 1 : 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);
    return NULL;
}

int queue_length(sequeue *sq) {
    if (sq == NULL) {
        return -1;
    }
    return sq->rear - sq->front;
}
  • 头文件
c 复制代码
#define N 100  // 队列最大容量
typedef int datatype;  // 数据类型

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);
int queue_length(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;
}
相关推荐
切糕师学AI3 小时前
环形缓冲区(Ring Buffer / Circular Buffer)详解:原理、优势、应用与高性能实现
数据结构·环形缓冲区
WolfGang0073214 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
晚枫歌F6 小时前
最小堆定时器
数据结构·算法
嫩萝卜头儿7 小时前
2 - 复杂度收尾 + 链表经典OJ
数据结构·算法·链表·复杂度
样例过了就是过了8 小时前
LeetCode热题100 分割等和子集
数据结构·c++·算法·leetcode·动态规划
木木_王8 小时前
嵌入式Linux学习 | 数据结构 (Day05) 栈与队列详解(原理 + C 语言实现 + 实战实验 + 易错点剖析)
linux·c语言·开发语言·数据结构·笔记·学习
北顾笙9809 小时前
day38-数据结构力扣
数据结构·算法·leetcode
m0_629494739 小时前
LeetCode 热题 100-----14.合并区间
数据结构·算法·leetcode
@小码农9 小时前
2026年3月Scratch图形化编程等级考试一级真题试卷
开发语言·数据结构·c++·算法
_日拱一卒11 小时前
LeetCode:226翻转二叉树
数据结构·算法·leetcode