641. 设计循环双端队列
题目描述
设计实现双端队列。
实现 MyCircularDeque 类:
- MyCircularDeque(int k):构造函数,双端队列最大为- k。
- boolean insertFront():将一个元素添加到双端队列头部。 如果操作成功返回- true,否则返回- false。
- boolean insertLast():将一个元素添加到双端队列尾部。如果操作成功返回- true,否则返回- false。
- boolean deleteFront():从双端队列头部删除一个元素。 如果操作成功返回- true,否则返回- false。
- boolean deleteLast():从双端队列尾部删除一个元素。如果操作成功返回- true,否则返回- false。
- int getFront()):从双端队列头部获得一个元素。如果双端队列为空,返回- -1。
- int getRear():获得双端队列的最后一个元素。 如果双端队列为空,返回- -1。
- boolean isEmpty():若双端队列为空,则返回- true,否则返回- false。
- boolean isFull():若双端队列满了,则返回- true,否则返回- false。
示例 1:
输入 ["MyCircularDeque", "insertLast", "insertLast", "insertFront", "insertFront", "getRear", "isFull", "deleteLast", "insertFront", "getFront"] [[3], [1], [2], [3], [4], [], [], [], [4], []] 输出 [null, true, true, true, false, 2, true, true, true, 4] 解释 MyCircularDeque circularDeque = new MycircularDeque(3); // 设置容量大小为3 circularDeque.insertLast(1); // 返回 true circularDeque.insertLast(2); // 返回 true circularDeque.insertFront(3); // 返回 true circularDeque.insertFront(4); // 已经满了,返回 false circularDeque.getRear(); // 返回 2 circularDeque.isFull(); // 返回 true circularDeque.deleteLast(); // 返回 true circularDeque.insertFront(4); // 返回 true circularDeque.getFront(); // 返回 4
提示:
- 1 <= k <= 1000
- 0 <= value <= 1000
- insertFront,- insertLast,- deleteFront,- deleteLast,- getFront,- getRear,- isEmpty,- isFull调用次数不大于- 2000次
解法
方法一:数组
利用循环数组,实现循环双端队列。
基本元素有:
- front:队头元素的下标
- size:队列中元素的个数
- capacity:队列的容量
- q:循环数组,存储队列中的元素
时间复杂度 \(O(1)\),空间复杂度 \(O(k)\)。其中 \(k\) 是队列的容量。
| 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 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 |  | 
| 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 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 |  | 
| 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 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 |  | 
| 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 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 |  | 
| 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 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 |  |