博客
关于我
循环队列的初始化、进队、出队、以及遍历打印
阅读量:798 次
发布时间:2019-03-21

本文共 1205 字,大约阅读时间需要 4 分钟。

/*顺序循环队列*/typedef int Status;typedef int ElemType;#define MAX 1024#define ERROR -1#define OK 0#include
#include
using namespace std;//设计节点结构体typedef struct SqNode{ ElemType elem[MAX]; int front; int rear;}SqNode;//初始化SqNode* InitSqCriQueue(){ SqNode* q = (SqNode*)malloc(sizeof(SqNode)); q->front = q->rear = 0; return q;} //判断队满bool IsFull(SqNode* q){ return((q->rear+1)%MAX==q->front);}//判断队空bool IsEmpty(SqNode* q){ return(q->front == q->rear);}//进队Status EnQueue(SqNode* q, ElemType e){ if (IsFull(q)) return ERROR; else { q->elem[q->rear] = e; q->rear=(q->rear+1)%MAX; return OK; }}//出队Status OutQueue(SqNode* q, ElemType* e){ if (IsEmpty(q)) return ERROR; else { *e = q->elem[q->front]; q->front=(q->front+1)%MAX; }}//打印Status Show(SqNode* q){ if (IsEmpty(q)) return ERROR; else { int p = q->front; while (q->rear != p) { cout << q->elem[p] << endl; //printf("行号----%d----\n",__LINE__); p = (p + 1) % MAX; } return OK; }}int main(){ SqNode* q = InitSqCriQueue(); EnQueue(q, 0); EnQueue(q, 1); EnQueue(q, 2); EnQueue(q, 3); EnQueue(q, 4); EnQueue(q, 5); Show(q); cout << "----------" << endl; int e; OutQueue(q, &e); Show(q);}

转载地址:http://ytogz.baihongyu.com/

你可能感兴趣的文章
MySQL面试宝典
查看>>
WAP短信:融合传统短信和互联网的新型通信方式
查看>>
mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
查看>>
Mysql面试题精选
查看>>
MySQL面试题集锦
查看>>
mysql面试题,存储引擎InnoDB和MyISAM
查看>>
mysql面试题:为什么MySQL单表不能超过2000W条数据?
查看>>
mysql面试题:创建索引时会不会锁表?
查看>>
mysql面试题:高度为3的B+树可以存放多少数据?
查看>>
mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
查看>>
mysql驱动、durid、mybatis之间的关系
查看>>
mysql驱动支持中文_mysql 驱动包-Go语言中文社区
查看>>
MySQL高可用之——keepalived+互为主从
查看>>
MySQL高可用切换_(5.9)mysql高可用系列——正常主从切换测试
查看>>
MySQL高可用解决方案
查看>>
MySQL高可用解决方案详解
查看>>
MYSQL高可用集群MHA架构
查看>>
MySQL高可用集群架构MHA企业级实战
查看>>
MySQL高级-MySQL存储引擎
查看>>
MySQL高级-MySQL并发参数调整
查看>>