服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言代码:用 C 语言实现一个循环队列

C语言代码:用 C 语言实现一个循环队列

2023-12-07 13:19鲨鱼编程 C/C++

本文将介绍如何使用C语言实现一个循环队列,包括队列的定义、入队、出队、判空和判满等操作。代码实现将遵循专业编程规范,并使用注释进行详细解释。

一、引言

队列是一种常见的数据结构,它遵循先进先出(FIFO)的原则。在实际应用中,队列经常被用于实现各种功能,如缓冲、任务调度等。而循环队列则是一种特殊的队列,它可以通过循环使用数组空间来避免队列中元素的浪费。在本文中,我们将使用C语言来实现一个循环队列,并通过代码和注释进行详细讲解。

C语言代码:用 C 语言实现一个循环队列

二、循环队列的定义

循环队列通常使用一个固定大小的数组和两个指针来实现。其中一个指针指向队头元素,另一个指针指向队尾元素的下一个位置。当队列为空时,两个指针指向同一个位置;当队列为满时,队尾指针指向队头指针的前一个位置。为了实现循环效果,我们需要对数组下标进行取模运算。

在C语言中,我们可以定义一个结构体来表示循环队列,如下所示:

#define MAXSIZE 10 // 定义队列的最大容量  
  
typedef struct {  
    int data[MAXSIZE]; // 存储数据的数组  
    int front; // 队头指针  
    int rear; // 队尾指针  
} CircularQueue;

三、循环队列的操作

(1) 初始化队列

在使用循环队列之前,我们需要对其进行初始化。初始化的过程就是将队头和队尾指针设置为同一个位置。代码如下:

void InitQueue(CircularQueue *Q) {  
    Q->front = Q->rear = 0; // 初始化队头和队尾指针  
}

(2) 判断队列是否为空

判断队列是否为空的方法很简单,只需要检查队头和队尾指针是否相等即可。代码如下:

int IsEmpty(CircularQueue *Q) {  
    return Q->front == Q->rear; // 如果队头和队尾指针相等,则队列为空  
}

(3) 判断队列是否已满

判断队列是否已满的方法也很简单,只需要检查队尾指针是否指向队头指针的前一个位置即可。代码如下:

int IsFull(CircularQueue *Q) {  
    return (Q->rear + 1) % MAXSIZE == Q->front; // 如果队尾指针的下一个位置是队头指针,则队列已满  
}

(4) 入队操作

入队操作就是将一个新元素添加到队列的尾部。在实现入队操作时,我们需要先判断队列是否已满。如果队列已满,则无法进行入队操作;否则,我们将新元素添加到队尾指针指向的位置,并将队尾指针向后移动一位。代码如下:

int EnQueue(CircularQueue *Q, int x) {  
    if (IsFull(Q)) { // 如果队列已满,则无法进行入队操作  
        return 0; // 入队失败,返回0  
    } else {  
        Q->data[Q->rear] = x; // 将新元素添加到队尾指针指向的位置  
        Q->rear = (Q->rear + 1) % MAXSIZE; // 队尾指针向后移动一位  
        return 1; // 入队成功,返回1  
    }  
}

(5) 出队操作

出队操作就是从队列的头部移除一个元素。在实现出队操作时,我们需要先判断队列是否为空。如果队列为空,则无法进行出队操作;否则,我们移除队头指针指向的元素,并将队头指针向后移动一位。代码如下:

int DeQueue(CircularQueue *Q, int *x) {  
    if (IsEmpty(Q)) { // 如果队列为空,则无法进行出队操作  
        return 0; // 出队失败,返回0  
    } else {  
        *x = Q->data[Q->front]; // 获取队头元素的值  
        Q->front = (Q->front + 1) % MAXSIZE; // 队头指针向后移动一位  
        return 1; // 出队成功,返回1  
    }  
}

(6) 获取队头元素

有时候,我们可能需要获取队头元素的值,但并不想将其从队列中移除。这时,我们可以实现一个获取队头元素的函数。代码如下:

int GetFront(CircularQueue *Q, int *x) {  
    if (IsEmpty(Q)) { // 如果队列为空,则无法获取队头元素  
        return 0; // 获取失败,返回0  
    } else {  
        *x = Q->data[Q->front]; // 获取队头元素的值  
        return 1; // 获取成功,返回1  
    }  
}

四、循环队列的完整实现

下面是一个完整的循环队列的实现,包括初始化队列、判断队列是否为空、判断队列是否已满、入队操作、出队操作和获取队头元素等操作。代码如下:

#include   
#include   
  
#define MAXSIZE 10 // 定义队列的最大容量  
  
typedef struct {  
    int data[MAXSIZE]; // 存储数据的数组  
    int front; // 队头指针  
    int rear; // 队尾指针  
} CircularQueue;  
  
// 初始化队列  
void InitQueue(CircularQueue *Q) {  
    Q->front = Q->rear = 0; // 初始化队头和队尾指针  
}  
  
// 判断队列是否为空  
int IsEmpty(CircularQueue *Q) {  
    return Q->front == Q->rear; // 如果队头和队尾指针相等,则队列为空  
}  
  
// 判断队列是否已满  
int IsFull(CircularQueue *Q) {  
    return (Q->rear + 1) % MAXSIZE == Q->front; // 如果队尾指针的下一个位置是队头指针,则队列已满  
}  
  
// 入队操作  
int EnQueue(CircularQueue *Q, int x) {  
    if (IsFull(Q)) { // 如果队列已满,则无法进行入队操作  
        return 0; // 入队失败,返回0  
    } else {  
        Q->data[Q->rear] = x; // 将新元素添加到队尾指针指向的位置  
        Q->rear = (Q->rear + 1) % MAXSIZE; // 队尾指针向后移动一位  
        return 1; // 入队成功,返回1  
    }  
}  
  
// 出队操作  
int DeQueue(CircularQueue *Q, int *x) {  
    if (IsEmpty(Q)) { // 如果队列为空,则无法进行出队操作  
        return 0; // 出队失败,返回0  
    } else {  
        *x = Q->data[Q->front]; // 获取队头元素的值  
        Q->front = (Q->front + 1) % MAXSIZE; // 队头指针向后移动一位  
        return 1; // 出队成功,返回1  
    }  
}  
  
// 获取队头元素  
int GetFront(CircularQueue *Q, int *x) {  
    if (IsEmpty(Q)) { // 如果队列为空,则无法获取队头元素  
        return 0; // 获取失败,返回0  
    } else {  
        *x = Q->data[Q->front]; // 获取队头元素的值  
        return 1; // 获取成功,返回1  
    }  
}
  
int main() {  
    CircularQueue Q; // 创建一个循环队列实例  
    int x, y; // 用于存储临时数据  
  
    // 初始化队列  
    InitQueue(&Q);  
  
    // 测试入队操作  
    for (int i = 1; i <= 5; i++) {  
        printf("入队元素 %d\n", i);  
        EnQueue(&Q, i);  
    }  
  
    // 测试获取队头元素操作  
    if (GetFront(&Q, &x)) {  
        printf("队头元素是 %d\n", x);  
    } else {  
        printf("队列为空,无法获取队头元素\n");  
    }  
  
    // 测试出队操作  
    while (!IsEmpty(&Q)) {  
        if (DeQueue(&Q, &y)) {  
            printf("出队元素是 %d\n", y);  
        } else {  
            printf("队列为空,无法进行出队操作\n");  
        }  
    }  
  
    // 测试队列是否为空  
    if (IsEmpty(&Q)) {  
        printf("队列为空\n");  
    } else {  
        printf("队列不为空\n");  
    }  
  
    return 0;  
}

这个测试程序首先创建一个循环队列实例,并进行初始化。然后,它进行了一系列入队操作,将1到5这五个数字依次入队。接着,它尝试获取队头元素,并打印出来。然后,它进行一系列出队操作,将队列中的元素依次移除,并打印出来。最后,它检查队列是否为空,并打印结果。通过这个测试程序,我们可以验证循环队列的实现是否正确。

五、总结与参考资料

本文介绍了如何使用C语言实现一个循环队列,包括队列的定义、入队、出队、判空和判满等操作。在实现过程中,我们遵循了专业编程规范,并使用注释进行了详细解释。循环队列是一种高效的数据结构,可以在各种应用中发挥重要作用。在实际使用中,我们可以根据具体需求对其进行扩展和优化。

原文地址:https://mp.weixin.qq.com/s?__biz=Mzg4Mjg0MTA3Ng==&mid=2247487043&idx=1&sn=8236c6363b0448c102642fdd84d454f9

延伸 · 阅读

精彩推荐
  • C/C++C语言实现链队列基本操作

    C语言实现链队列基本操作

    这篇文章主要为大家详细介绍了C语言实现链队列基本操作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    似曾不相识9402022-01-11
  • C/C++C++学习笔记之类成员指针

    C++学习笔记之类成员指针

    类成员指针时指可以指向类的非静态成员的指针,下面这篇文章主要给大家介绍了关于C++类成员指针的相关资料,文中通过实例代码介绍的非常详细,需要的朋...

    Ofnoname6832022-11-13
  • C/C++用C语言实现简易通讯录

    用C语言实现简易通讯录

    这篇文章主要为大家详细介绍了用C语言实现简易通讯录,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    Quinn09186872021-06-20
  • C/C++c++关键字mutable深入解析

    c++关键字mutable深入解析

    先说用法,mutable关键字只能修饰非静态以及非常量成员变量,使用mutable修饰的成员变量在const函数中的值是可以修改的...

    C++教程网9432021-01-01
  • C/C++C语言实现电子英汉词典系统

    C语言实现电子英汉词典系统

    这篇文章主要为大家详细介绍了C语言实现电子英汉词典系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    普通学长6682022-12-15
  • C/C++C++实现简易五子棋游戏

    C++实现简易五子棋游戏

    这篇文章主要为大家详细介绍了C++实现简易五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    PlanetRT7022021-09-15
  • C/C++C++ 中malloc()和free()函数的理解

    C++ 中malloc()和free()函数的理解

    这篇文章主要介绍了C++ 中malloc()和free()函数的理解的相关资料,这里提供用法示例帮助大家理解这部分知识,需要的朋友可以参考下...

    小小白杨1237832021-05-27
  • C/C++C++基于递归和非递归算法求二叉树镜像的方法

    C++基于递归和非递归算法求二叉树镜像的方法

    这篇文章主要介绍了C++基于递归和非递归算法求二叉树镜像的方法,针对二叉树遍历结合实例形式分析了递归与非递归算法的实现与使用技巧,需要的朋友可...

    难免有错_11972021-05-10