T& front();
T& back();
void pop_front();
void push_back(const T&);
void pop_back();
void push_front(const T&);
实现方案一:
由于不需要随机访问,使用链表实现再合适不过。
既可以单独写一个类,也可以私有继承线性表的链表描述,“窄化”线性表的功能。
实现方案二:
如果仅仅“窄化”线性表的数组描述,插入删除的性能太差。
解决方案就是循环数组。
循环数组
关键点:
-
将数组头和尾连接起来,形成一个环(就像一个12点的钟表一样),
-
使用theFront、theBack来分别表示数组头部元素的前一个位置、尾部元素的位置。
-
当且仅当 theFront = theBack 时, 队列为空
-
为了避免数组存满的时候 theFront = theBack 这种情况, 所以在任意时刻队列中的元素的个数最多为 arrayLength-1,这个时候需要去扩容。
-
注意在循环数组的意义下,向后移动是 i = ( i + 1 ) % a r r a y L e n g t h i = (i+1)\%arrayLength i=(i+1)%arrayLength,
-
向前移动是 i = ( i − 1 + a r r a y L e n g t h ) % a r r a y L e n g t h i = (i-1+arrayLength)\%arrayLength i=(i−1+arrayLength)%arrayLength(减法时,为了避免为负,要加上模数)。
实际上,c++的stl使用的是数组来实现队列,因为,在性能在数组描述确实更加优秀。
//
// Created by MAC on 2020/10/7.
//
#ifndef DATASTRUCTURE_ARRAYDEQUE_H
#define DATASTRUCTURE_ARRAYDEQUE_H
#include
using std::cout;
template
class ArrayDeque {
static const int DEFAULT_CAPACITY = 8;
T* arr;
// length是队列的长度,也就是队列里面元素的个数, arrayLength是数组的长度
// theFront 是真实队首元素的前一个位置, theBack就是队尾元素的位置
int length, arrayLength, theFront, theBack;
void expand();
void checkEmpty(){
if(empty()){
throw “queue is empty.”;
}
}
public:
ArrayDeque();
virtual ~ArrayDeque();
virtual bool empty();
virtual int size();
virtual T& front();
T& back();
void pop_front();
void push_back(const T&);
void pop_back();
void push_front(const T&);
};
template
ArrayDeque::ArrayDeque() {
length = 0;
theFront = theBack = 0;
arrayLength = DEFAULT_CAPACITY;
arr = new T[DEFAULT_CAPACITY];
}
template
ArrayDeque::~ArrayDeque() {
delete [] arr;
}
template
bool ArrayDeque::empty() {
return theFront==theBack;
}
template
int ArrayDeque::size() {
return (arrayLength+theBack-theFront)%arrayLength;
}
template
T &ArrayDeque::front() {
checkEmpty();
return arr[(theFront+1)%arrayLength];
}
template
T &ArrayDeque::back() {
checkEmpty();
return arr[theBack];
}
template
void ArrayDeque::pop_front() {
checkEmpty();
theFront = (theFront+1)%arrayLength;
// 队首元素要析构
arr[theFront].~T();
length–;
}
template
void ArrayDeque::push_back(const T & t) {
if( (theBack+1)%arrayLength == theFront ){
expand();
}
theBack = (theBack+1)%arrayLength;
arr[theBack] = t;
length++;
}
template
void ArrayDeque::pop_back() {
checkEmpty();
arr[theBack].~T();
theBack = (theBack-1+arrayLength)%arrayLength;
length–;
}
template
void ArrayDeque::push_front(const T & t) {
if( (theBack+1)%arrayLength == theFront){
expand();
}
arr[theFront] = t;
theFront = (theFront-1+arrayLength)%arrayLength;
length++;
}
// 当且仅当 (theBack+1)%arrayLength == theFront 的时候,才会去扩容
// 此时 length = arrayLength - 1;
// 这个时候不仅仅要扩充容量,并且要重新调整元素的位置,满足"环形要求"
// 调整的方式有很多,不妨这样调整,所有元素靠前放置,也就是填充 [0,length-1] i,e, [0,arrayLength - 2]
// 具体来说,就要判断是否成环(头是否在尾的后面),来具体操作
template
void ArrayDeque::expand() {
T* newArray = new T[arrayLength*2];
int start = (theFront+1)%arrayLength;
if(start<2){
for(int i = start;i<arrayLength-1+start;i++){
newArray[i-start] = arr[i];
}
}else{
int pos = 0;
for(int i = start;i<arrayLength;i++){
newArray[pos++] = arr[i];
}
for(int i=0;i<=theBack;i++){
newArray[pos++] = arr[i];
}
}
theFront = arrayLength*2 - 1;
theBack = arrayLength - 2;
arrayLength = arrayLength*2;
delete [] arr;
arr = newArray;
}
#endif //DATASTRUCTURE_ARRAYDEQUE_H
//
// Created by MAC on 2020/10/7.
//
#include “ArrayQueue.h”
#include
#include “ArrayDeque.h”
#include
// 0 1 2 3 分别表示 size() front() push(x) pop();
// 下面开始对拍
//using namespace std;
//int main(){
// srand(100);
// deque dq;
// ArrayDeque mq;
// for(int i=0;i<100000;i++){
// long x = rand();
// long op = x%7;
// switch (op) {
最后
Java架构进阶面试及知识点文档笔记
这份文档共498页,其中包括Java集合,并发编程,JVM,Dubbo,Redis,Spring全家桶,MySQL,Kafka等面试解析及知识点整理
Java分布式高级面试问题解析文档
其中都是包括分布式的面试问题解析,内容有分布式消息队列,Redis缓存,分库分表,微服务架构,分布式高可用,读写分离等等!
互联网Java程序员面试必备问题解析及文档学习笔记
Java架构进阶视频解析合集
// long op = x%7;
// switch (op) {
最后
Java架构进阶面试及知识点文档笔记
这份文档共498页,其中包括Java集合,并发编程,JVM,Dubbo,Redis,Spring全家桶,MySQL,Kafka等面试解析及知识点整理
[外链图片转存中…(img-U7bF9yKl-1719154115687)]
Java分布式高级面试问题解析文档
其中都是包括分布式的面试问题解析,内容有分布式消息队列,Redis缓存,分库分表,微服务架构,分布式高可用,读写分离等等!
[外链图片转存中…(img-MgQbO4SA-1719154115688)]
互联网Java程序员面试必备问题解析及文档学习笔记
[外链图片转存中…(img-twAEB0oy-1719154115689)]
Java架构进阶视频解析合集