【数据结构】循环队列原理与代码

理论

  • 存在的意义:
    将顺序队列从逻辑上视为一个环。解决"假溢出"(出队入队连续操作后两个指针均到数组末端maxsize-1处,虽然队里没有元素但无法让元素进队)。
  • 两种定义
    1.题目是队列非空时队头指针和队尾指针分别指向队头元素和队尾元素时,则初始时front=0,rear=n-1,每次入队时rear++再放新元素。
    这种情况下 q.front=(q.rear+maxsize-q.length+1)%maxsize
    2.而队尾指针指向队尾元素的下一个时,则front=rear=0,每次入队时先放新元素再rear++;
    这种情况下 q.front==(q.rear+maxsize-q.length)%maxsize

总结:front初始只有可能为0!

  • 严蔚敏版的定义
    【严书规定】初始front=rear=0;非空队列中头指针始终指向队头,尾指针始终指向队尾的下一个位置。
    初始:Q.front=Q.rear=0;
    进队:Q.rear=(Q.rear+1)%MaxSize;
    出队:Q.front=(Q.front+1)%MaxSize;
    队列长度 (Q.rear-Q.front+MaxSize)%MaxSize;
  • 区分队满的三种解决办法
  1. 牺牲一个单元,入队时少用一个队列单元,否则队空队满的判断条件相同导致无法确定。
    队满条件:(Q.rear+1)%MaxSize==Q.front;//rear所指的单元始终为空。
    队空条件:Q.rear=Q.front;
    队列长度:(Q.rear-Q.front+MaxSize)%MaxSize;
  2. 增设表示元素个数数据成员Q.size
  3. 增设tag,删除时tag=0;入队时tag=1;当Q.front==Q.rear时可区分。(操作完后检查空满并赋值tag)

注意:出队入队之前的检查空满的条件

  • 循环链队判空:rear->next ==rear

代码练习

https://www.lintcode.com/problem/955/

python 复制代码
class CircularQueue:
    def __init__(self, n):
        # do intialization if necessary
        self.arr = [None]*n
        self.head, self.tail = 0, -1 #队尾先+1再放元素
        self.size = n
    """
    @return:  return true if the array is full
    """
    def isFull(self):
        return self.head == (self.tail + 1) % self.size and not self.arr[self.tail] is None
        
    """
    @return: return true if there is no element in the array
    """
    def isEmpty(self):
        return self.arr[self.tail] is None #队尾始终指向最后一个元素
        
    """
    @param element: the element given to be added
    @return: nothing
    """
    def enqueue(self, element):
        self.tail = (self.tail + 1) % self.size
        self.arr[self.tail] = element

    """
    @return: pop an element from the queue
    """
    def dequeue(self):
        ele = self.arr[self.head]
        self.arr[self.head] = None
        self.head = (self.head + 1) % self.size
        return ele
相关推荐
偷光10 分钟前
浏览器中的隐藏IDE: Elements (元素) 面板
开发语言·前端·ide·php
DKPT14 分钟前
JVM栈溢出和堆溢出哪个先满?
java·开发语言·jvm·笔记·学习
Rock_yzh3 小时前
AI学习日记——参数的初始化
人工智能·python·深度学习·学习·机器学习
gopyer4 小时前
180课时吃透Go语言游戏后端开发6:Go语言的循环语句
开发语言·游戏·golang·循环语句
青衫客365 小时前
基于 Python 构建的安全 gRPC 服务——TLS、mTLS 与 Casbin 授权实战
python·安全·微服务
-dzk-6 小时前
【3DGS复现】Autodl服务器复现3DGS《简单快速》《一次成功》《新手练习复现必备》
运维·服务器·python·计算机视觉·3d·三维重建·三维
楼田莉子7 小时前
Qt开发学习——QtCreator深度介绍/程序运行/开发规范/对象树
开发语言·前端·c++·qt·学习
摩羯座-185690305947 小时前
爬坑 10 年!京东店铺全量商品接口实战开发:从分页优化、SKU 关联到数据完整性闭环
linux·网络·数据库·windows·爬虫·python
ACERT3337 小时前
5.吴恩达机器学习—神经网络的基本使用
人工智能·python·神经网络·机器学习
韩立学长7 小时前
【开题答辩实录分享】以《基于python的奶茶店分布数据分析与可视化》为例进行答辩实录分享
开发语言·python·数据分析