ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

循环队列实现C

2021-10-14 19:34:24  阅读:222  来源: 互联网

标签:cout 队列 ElemType SqQueue 实现 循环 front QueueSize rear


#include<iostream>
using namespace std;
#define QueueSize 50
typedef char ElemType;
typedef struct
{
	ElemType data[QueueSize];
	int front,rear;
}SqQueue;

void InitQueue(SqQueue *&q)//初始化队列
{
	q=new SqQueue;
	q->front=q->rear=0;
}
void EnQueue(SqQueue *&q,ElemType x)//入队列 
{
	if((q->rear+1)%QueueSize==q->front)
	{
		cout<<"上溢,无法入队"<<endl; 
	}
	else
	{
		q->rear=(q->rear+1)%QueueSize;
		q->data[q->rear]=x;
		cout<<"入对成功"<<endl; 
	 } 
}

void DeQueue(SqQueue *&q)//出队 
{
	if(q->rear==q->front)
	{
		cout<<"下溢,无法出队"<<endl;
	}
	else
	{
		q->front=(q->front+1)%QueueSize;//出队,对头指针+1 
		cout<<"出队元素为:"<<q->data[q->front]<<endl;//取出队头元素 
	}
}

void GetQueue(SqQueue *q)//获取队头元素 
{
	if(q->rear ==q->front)
	{
		cout<<"空队列,无元素"<<endl;//空队列 
	}
	else
	{
		q->front =(q->front +1)%QueueSize;
		cout<<"头元素为:"<<q->data[q->front]<<endl;
	} 
}

void QueueEmpty(SqQueue *q)//判断队列是否为空 
{
	if(q->front==q->rear)
	{
		cout<<"队列为空"<<endl; 
	}
	else
	{
		cout<<"队列不为空"<<endl;
	}

} 

标签:cout,队列,ElemType,SqQueue,实现,循环,front,QueueSize,rear
来源: https://blog.csdn.net/luckyspecter/article/details/120770831

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有