《数据结构与算法》之队列

《数据结构与算法》之链表
《数据结构与算法》之链栈
《数据结构与算法》之排序
《数据结构与算法》之二分查找
《数据结构与算法》之二叉树

如何理解“队列”?
你可以把它想象成排队买票,先来的先买,后来的人只能站末尾,不允许插队。先进者先出,这就是典型的“队列”。我们知道,栈只支持两个基本操作:入栈 push()和出栈 pop()。队列跟栈非常相似,支持的操作也很有限,最基本的操作也是两个:入队 enqueue(),放一个数据到队列尾部;出队 dequeue(),从队列头部取一个元素。所以,队列跟栈一样,也是一种操作受限的线性表数据结构。队列的实现有两种方式,基于数组来实现的栈我们称为顺序队列,基于链表来实现的栈我们称为链式队列
我这里只实现了顺序队列,这个队列是一个循环队列。它的好处在于避免了队列中的数据搬移操作,有利必有弊,坏处就是会浪费掉一个存储空间。Demo地址

1.1 实现

/// 循环队列、可以避免顺序队列的数据搬移操作,但是会浪费一个存储空间
class ArrayQueue: NSObject {
    var arrayQueue: Array<Any>?
    var size: Int? //队列大小
    var head: Int? //头下标
    var tail: Int? //尾下标
    
    init(size: Int) {
        self.size = size
        self.head = 0
        self.tail = 0
        self.arrayQueue = Array.init()
    }
}

1.2进队列

    /// 进队列
    /// - Parameter data: 进队列数据
    /// - Returns: 进队列结果
    func enqueue(data: Any) -> Bool {
        if (tail! + 1) % size! == head! {
            //队列已满
            return false
        }
        
        if arrayQueue?.count == size {
            arrayQueue![tail!] = data
        }else {
            arrayQueue?.append(data)
        }
        tail = (tail! + 1) % size!
        return true
    }

1.3出队列

    /// 出队列
    /// - Returns: 队列数据
    func dequeue() -> Any? {
        if head! == tail! {
            return nil
        }
        let data = arrayQueue![head!]
        head = (head! + 1) % size!
        return data
    }

1.4用法

        let arrayQueue = ArrayQueue.init(size: 4)
        for i in 0 ... 4 {
            print("进队列\(arrayQueue.enqueue(data: i))")
        }
        for _ in 0 ... 4 {
            print("出队列\(arrayQueue.dequeue())")
        }
        for i in 4 ... 7 {
            print("进队列\(arrayQueue.enqueue(data: i))")
        }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值