文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

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

头文件声明


#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;
}

再贴个测试结果的图:

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯