现在已经有一段时间了,我想我终于破解了它,它适用于我所有的测试,但我觉得会有一些琐碎的问题。这是双面队列(deque)的大量简化版本,每次添加值时,都会生成一个临时数组来存储所有值,然后附加新值。我相信这是最容易解释的方式。如果有人可以请你仔细检查我是对的,这里没有什么明显的错误,我会非常感激。非常感谢你们! :)
public class ArrayBasedDeque<EltType> implements Deque<EltType> {
private final int CAPACITY = 10;
private int capacity;
private int end;
private EltType deque[];
public ArrayBasedDeque() {
this.capacity = CAPACITY;
deque = (EltType[]) (new Object[capacity]);
}
public EltType first() {
return deque[0];
}
public EltType last() {
return deque[end-1];
}
public boolean isEmpty() {
return end == 0;
}
public int size() {
return deque.length;
}
public boolean isFull() {
return end == capacity;
}
public void insertFirst(EltType inserted) {
if (!isEmpty()) {
EltType[] tempArray;
capacity+=1;
tempArray = (EltType[]) new Object[capacity];
for(int i=0;i<end;i++){
tempArray[i+1] = deque[i];
}
deque=tempArray;
}
deque[0] = inserted;
end++;
}
public void insertLast(EltType last) {
if (isFull()){
EltType[] tempArray;
capacity+=1;
tempArray = (EltType[]) new Object[capacity];
for (int i=0;i<end;i++) {
tempArray[i] = deque[i];
}
// System.out.print(deque[end]);
}
deque[end] = last;
end++;
}
public EltType removeFirst() {
EltType[] tempArray;
EltType returned = deque[0];
tempArray = (EltType[]) new Object[capacity];
for (int i=1;i<capacity;i++) {
tempArray[i-1] = deque[i];
}
deque = tempArray;
end--;
return returned;
}
public EltType removeLast() {
EltType[] tempArray;
EltType returned = deque[end-1];
tempArray = (EltType[]) new Object[capacity];
for (int i=0;i<capacity;i++) {
tempArray[i] = deque[i];
}
deque = tempArray;
end--;
return returned;
}
}
答案 0 :(得分:3)
一些评论:
T
或E
作为类型参数的名称,而不是EltType
CAPACITY
重命名为DEFAULT_CAPACITY
,并将其设为静态。first()
也会返回一个值last()
为0,removeLast()
,removeFirst()
和end
应该抛出适当的例外removeFirst
和removeLast
中,您的循环边界为capacity
而不是end
System.arraycopy
作为复制数组的简单方法deque
中找到insertLast
的作业 - 因此您在评论中看到的例外情况。我不确定我是否认为仅仅使用ArrayList<T>
就可以获益...但是,单独Deque
实施的主要目的是为两个头部添加和拖尾便宜......这里我们都没有!
...当然只需使用ArrayDeque
或LinkedList
:)
答案 1 :(得分:0)
我建议