栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

学习c++顺序队列的基本操作(王道数据结构顺序队列)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

学习c++顺序队列的基本操作(王道数据结构顺序队列)

#define MaxSize 10
typedef struct
{
    ElemType data[MaxSize];
    int front,rear;
}SqQueue;
//顺序队的初始化
void InitQueue(SqQueue &q)
{
    q.front=q.rear=0;
}
//队列判空
bool QueueEmpty(SqQueue q)
{
    if(q.rear == q.front)
        return true;
    else
        return false;
}
//入队操作
bool EnQueue(SqQueue &q,ElemType x)
{
    if(队满)
        return false;
    q.data[q.rear]=x;
    q.rear=q.rear+1;
    return true;
}
//循环队列,保证队真的满  牺牲一个空间  才能区别  队空和队满的情形
bool EnQueue(SqQueue &q,ElemType x)
{
    if((q.rear +1)%MaxSize==q.front)
        return false;
    q.data[q.rear]=x;
    q.rear=(q.rear+1)%MaxSize;
    return true;
}
//出队操作
bool deQueue(SqQueue &q,ElemType &e)
{
    if(q.rear == q.front)
    {
        return false;
    }
    x = q.data[q.front];
    q.front = (q.front+1)%MaxSize;
    return true;
}
//查找对头
bool GetHead(SqQueue q,ElemType &e)
{
    if(q.rear == q.front)
        return false;
    e = q.data[q.front];
    return true;
}
//循环队列为了不浪费存储空间   加个size来记录出队减一,入队加一  size = MaxSize 为满 
// size =0;空 
//或者加给tag来记录  (进队1,q.rear==q.front) 满
//出队(0 ,q.rear == q.front) 空
//注意队尾指针指向的是最后一个结点 ,还是最后一个结点的下一个位置,这个很关键,相应操作随之而变

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/864900.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号