Swiftで使うQueueのテンプレート
![イメージ](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhBEV0Us61PQdTxfO_CiM-HBvTEhBM1THtSQdoXV6zX0AVmHhPuOZNs_SpItcFIqMW15TX3BWBeeAqbNmwYaNZNBQkRIEbOLbY-q8Eptj8uPYqL14TuuIdp1UTLFzpTEVsXoJWw7piNdVjEW0mJgt2WHZ0PwAPTRFYlXhYbR_AMEUrRKMmpCQFRsLxq3WuK/w640-h640/swift-og.png)
SwiftのQueue そもそもSwiftに標準でQueueは存在しないのでBFSを書きたいときに自分で定義する必要があるよう。 今後書きたいときには以下の内容を使おうと思ってメモとして取っておく。 struct Queue < T > { private var elements : [ T ] = [ ] mutating func enqueue ( _ value : T ) { elements . append ( value ) } mutating func dequeue ( ) - > T ? { return elements . isEmpty ? nil : elements . removeFirst ( ) } func isEmpty ( ) - > Bool { return elements . isEmpty } var count : Int { return elements . count } }