队列的那些事儿

本文探讨了队列的基本概念,以其先进先出的特性为例,如排队买票。文章通过数组和链表两种方式详细介绍了如何实现队列。
前言

前面描述了堆栈是先进后入的方式,队列则是我们传统的先进先出方式,例如排队买票,如果先去的人肯定是先买到票,后去的人则是后买到票。我们实现的时候仍然采用数组和链表的形式分别实现

数组实现
#include<stdio.h>
#include<stdlib.h>
#define MAX 5
// 定义队列结构体
typedef struct queue {
    int data[MAX];
    int front;
    int rear;
}Queue;
// 初始化
void init(Queue *p) {
    p -> front = p -> rear = 0;
}
// 是否满
int isFull(Queue *p) {
    return p -> rear > MAX - 1;
}
// 入队列
void enQueue(Queue *p, int data) {
    if(isFull(p))
        printf("%d不能够入队列,队列已满\n", data);
    else
        p -> data[p -> rear++] = data;
}
// 是否为空
int isEmpty(Queue *p) {
    return p -> front == MAX;
}
// 出队列
int deQueue(Queue *p) {
    return p -> data[p -> front++];
}
int main() {
    Queue s;
    init(&s);
    for(int i=0; i<6; i++)
        enQueue(&s, i);
    while(!isEmpty(&s))
        printf("%d ", deQueue(&s));
    printf("\n");
    return 0;
}
链表实现
#include<stdio.h>
#include<stdlib.h>
// 定义每个节点
typedef struct node {
    int data;
    struct node *next;
} Node;
// 定义队列节点
typedef struct queue {
    Node *front;
    Node *rear;
} Queue;
// 初始化
void init(Queue *p) {
    p -> front = p -> rear = (Node *) malloc(sizeof(Node));
}
//入队列
void enQueue(Queue *p, int data) {
    Node *newNode;
    newNode = (Node *) malloc(sizeof(Node));
    newNode -> data = data;
    p -> rear -> data = data;
    p -> rear -> next = newNode;
    p -> rear = newNode;
}
//出队列
int deQueue(Queue *p) {
    Node *r;
    int data;
    r = p -> front;
    data = r -> data;
    p -> front = r -> next;
    free(r);
    return data;
}
// 判断是否为空
int isEmpty(Queue *p) {
    return p -> front == p -> rear;
}
int main() {
    Queue s;
    init(&s);
    for(int i=0; i<6; i++)
        enQueue(&s, i);
    while(!isEmpty(&s))
        printf("%d ", deQueue(&s));
    printf("\n");
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值