iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言实现循环队列基本操作
  • 734
分享到

C语言实现循环队列基本操作

2024-04-02 19:04:59 734人浏览 八月长安
摘要

循环队列依靠取模运算,实现队列中数据元素的逻辑成环操作。其相比队列的顺序存储实现,可以避免“假溢出”的问题。 头文件声明 #include <stdio.h> #in

循环队列依靠取模运算,实现队列中数据元素的逻辑成环操作。其相比队列的顺序存储实现,可以避免“假溢出”的问题。

头文件声明


#include <stdio.h>
#include <stdlib.h>


//数据元素上限
#define MaxSize 50
//定义数据类型
typedef int ElemType;

typedef struct SqQueue
{
 ElemType data[MaxSize];//数组-存放数据元素
 int front, //队头指针
  rear; //队尾指针
}SqQueue;

//初始化队列
void InitQueue(SqQueue *q);
//判断队列是否为空
int EmptyQueue(SqQueue q);
//入队操作
int EnQueue(SqQueue *q,ElemType e);
//出队操作
int DeQueue(SqQueue *q,ElemType* e);
//获取队列长度
int LengthQueue(SqQueue q);
//获取队头元素
void GetHead(SqQueue q,ElemType* e);
//打印队列
void printSqQueue(SqQueue q);

函数实现


#include "SqQueue.h"



//初始化队列
void InitQueue(SqQueue *q){
 //队头指针-队尾指针,同时指向队首元素
 q->front=q->rear=0;
}

//判断队列是否为空
int EmptyQueue(SqQueue q){
 //队头指针和队尾指针指向同一个元素,则为空队列
 return q.front==q.rear;
}

//入队操作
int EnQueue(SqQueue *q,ElemType e){
 //判断是否队满
 if ((q->rear+1)%MaxSize==q->rear)
  return -1;
 //入队操作
 q->data[q->rear]=e;//添加数据元素-将队尾元素值置为e
 q->rear=(q->rear+1)%MaxSize;//尾指针向前移动,队尾指针++
 return 1;
}
//出队操作
int DeQueue(SqQueue *q,ElemType* e){
 //判断是否队空
 if ((q->rear+1)%MaxSize==q->front)
  return -1;
 //保存数据
 *e=q->data[q->front];
 //出队操作
 q->front=(q->front+1)%MaxSize;
 return 1;
}
//获取队列长度
int LengthQueue(SqQueue q){
 return (q.rear-q.front+MaxSize)%MaxSize;
}

//获取队头元素
void GetHead(SqQueue q,ElemType* e){
 //判断队列是否为空
 if (q.front==q.rear)
  return;
 //获取队头元素的值
 *e=q.data[q.front];
}

//打印队列
void printSqQueue(SqQueue q){
 //辅助指针
 int pIndex;
 //打印队列元素
 pIndex=q.front;
 while (pIndex<q.rear)
 {
  printf("%4d",q.data[pIndex++]);
 }
 printf("\n");
}

函数测试


#include "SqQueue.h"

int main(int arGC,char** argv){
 //声明队列
 SqQueue sQueue;
 int i;
 ElemType data;
 //初始化队列
 InitQueue(&sQueue);
 //获取队头指针和队尾指针的值
 printf("frontVal=%d,rearVal=%d\n",sQueue.front,sQueue.rear);
 //判断队列是否为空
 printf("is Empty?%d\n",EmptyQueue(sQueue));
 //入队操作
 for (i=0;i<20;i++)
 {
  EnQueue(&sQueue,i+1);
 }
 //判断队列是否为空&获取队列长度
 printf("is Empty?%d,len=%d\n",EmptyQueue(sQueue),LengthQueue(sQueue));
 //打印队列元素
 printSqQueue(sQueue);
 //出队操作
 DeQueue(&sQueue,&data);
 printf("the aimed value is %d\n",data);
 //判断队列是否为空&获取队列长度
 printf("is Empty?%d,len=%d\n",EmptyQueue(sQueue),LengthQueue(sQueue));
 //打印队列元素
 printSqQueue(sQueue);
 //获取队头元素值
 GetHead(sQueue,&data);
 printf("the head value is %d\n",data);
 return 0;
}

再贴个测试结果的图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: C语言实现循环队列基本操作

本文链接: https://www.lsjlt.com/news/136520.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c语言怎么计算字符串长度
    在C语言中,可以使用内置的strlen()函数来计算字符串的长度。该函数位于string.h头文件中。以下是一个示例代码: #inc...
    99+
    2024-05-14
    c语言
  • c语言怎么判断三个数的大小
    可以通过比较三个数之间的大小关系来判断它们的大小。以下是一个示例代码: #include <stdio.h> int ...
    99+
    2024-05-14
    c语言
  • c++排序函数sort怎么使用
    在C++中,使用sort函数对容器中的元素进行排序,可以按照默认的升序排列,也可以自定义排序规则。 下面是一个简单的例子,对一个ve...
    99+
    2024-05-14
    c++
  • c++中string的compare函数怎么使用
    在C++中,可以使用string的compare函数来比较两个string对象的大小。该函数的原型如下: int compare(c...
    99+
    2024-05-14
    c++
  • c++中string的compare函数有什么用
    c++中string的compare函数用于比较两个字符串的大小关系。该函数返回一个整数值,表示两个字符串的比较结果。 具体来说,如...
    99+
    2024-05-14
    c++
  • c++中print函数的功能有哪些
    在C++中,通常使用std::cout来进行输出操作,而不是使用print函数。std::cout是C++标准库中的一个输出流对象,...
    99+
    2024-05-14
    c++
  • c语言数据结构怎么使用
    在C语言中,数据结构可以通过定义结构体来实现。以下是一些常见的数据结构的使用方法示例: 链表: #include <std...
    99+
    2024-05-14
    c语言
  • c++中print函数的用法是什么
    在C++中没有内置的print函数,但可以使用cout来输出内容到控制台。cout是C++标准库中的一个输出流对象,可以使用<...
    99+
    2024-05-14
    c++
  • c++中concept的用法是什么
    在C++20中,Concept是一种新的语言特性,用于定义类型要求和约束。Concept可以被用来约束函数模板、类模板和普通函数的参...
    99+
    2024-05-14
    c++
  • c++中concept的作用是什么
    在C++中,concept的作用是定义一种通用的约束,用于限制模板参数的类型范围。通过使用concept,可以在编译时对模板参数进行...
    99+
    2024-05-14
    c++
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作