-
Notifications
You must be signed in to change notification settings - Fork 178
/
Copy pathday 18.swift
42 lines (34 loc) · 833 Bytes
/
day 18.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
struct Stack<Element> {
var items = [Element]()
mutating func push(_ item: Element) {
items.append(item);
}
mutating func pop() -> Element {
return items.removeLast();
}
}
struct Queue<Element> {
var items = [Element]()
mutating func enqueue(_ item: Element) {
items.append(item);
}
mutating func dequeue() -> Element {
return items.removeFirst();
}
}
class Solution {
var stack = Stack<Character>();
var queue = Queue<Character>();
func pushCharacter(ch: Character){
stack.push(ch);
}
func popCharacter() -> Character {
return stack.pop();
}
func enqueueCharacter(ch: Character){
queue.enqueue(ch);
}
func dequeueCharacter() -> Character {
return queue.dequeue();
}
}