美文网首页
CS基础:队列

CS基础:队列

作者: ChrisPzzz | 来源:发表于2017-02-08 17:39 被阅读27次

CS 基础:队列

队列

队列:只允许在一端进行插入操作,而在另一端进行删除操作的线性表。

队列是先进先出(First In First Out)的线性表。允许插入的一端称为队尾,允许删除的一端成为队头。

实现队列

基于双向链表的基础上来实现这个队列结构。

实现一个队列结构体

首先建立一个 List 链表类,在队列中使用链表来储存元素:

public struct Queue<T>{
    fileprivate var list = List<T>()
}

入队

给队列添加一个入队函数:

public mutating func enqueue(element:T) {
        list.append(element:element)
    }

出队

给队列添加一个出队函数:

public mutating func dequeue() -> T? {
        guard !list.isEmpty,let element = list.first else {
            return nil
        }
        list.remove(node:element)
        return element.value
    }

查看队首元素

public func peek() -> T? {
        return list.first?.value
    }
    
//是否为空队列
    public var isEmpty : Bool?{
        return list.isEmpty
    }
    

实践

添加一个 extension 帮助打印输出:

extension Queue{
    public var description : String{
        return list.description
    }
}

输入:

var queue = Queue<String>()
queue.enqueue(element:"熊大")
queue.enqueue(element:"熊二")
queue.enqueue(element:"周末")
queue.enqueue(element:"蛋蛋")

print(queue.description)

queue.dequeue()
print(queue.description)

输出:

[熊大 , 熊二 , 周末 , 蛋蛋]
[熊二 , 周末 , 蛋蛋]

end

相关文章

  • CS基础:队列

    CS 基础:队列 队列 队列:只允许在一端进行插入操作,而在另一端进行删除操作的线性表。 队列是先进先出(Firs...

  • 第二周

    这周下了很多课程,导致自己可能分心。总结一下: cs50 程序设计基础 cs6.001 cs50和cs6.001的...

  • 腾讯蓝鲸

    基础 IaaSzookeeperredisMySQLITILCMDBjfROGdocker hub 前端 w3cs...

  • CS域和PS域的区别

    cs域与ps域概念与区别 CS域、PS域分别是什么意思?区别在哪? 1、基础概念: CS:CircuitSwitc...

  • CS基础:栈

    栈 栈:限定仅在表尾进行插入和删除操作的线性表。 其中允许插入和删除的一端成为栈顶,另一端成为栈底,不含任意元素的...

  • 栈 队列 双端队列 优先队列 基础知识

    栈 队列 双端队列 优先队列 基础知识• Stack:先入后出 first in last out 简写FILO ...

  • CS190 Scalable Machine Learning

    CS190 Scalable Machine Learning Spark - 1 Python 基础 Part ...

  • 春招笔记

    Linux支持的IPC:管道,消息队列,共享内存,信号量,Socket。只有Socket支持CS模式,其他的也可以...

  • 数组实现环形队列

    利用数组结构在队列的基础下用取模算法来实现环形队列。 环形队列拥有复用功能。 主要算法思想:1)front指向队列...

  • iOS GCD (二 ) dispatch_group 队列组

    iOS GCD (一) 任务+队列 基础组合iOS GCD (二 ) dispatch_group 队列组iO...

网友评论

      本文标题:CS基础:队列

      本文链接:https://www.haomeiwen.com/subject/hlhbittx.html