在java中实现deque的问题

时间:2011-02-07 22:30:11

标签: java deque

抱歉,继续我在这里的问题:here我试图运行此方法从双面队列(deque)中删除泛型值(EltType),但我一直收到错误在那里,我调用insertFirst两次,并将值“3”插入数组两次,然后,当我运行removeFirst时,它将打印出“3”一次,然后“Null”。有人能帮帮我吗?

class ArrayBasedDeque<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 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;
    return returned;
  }


  public boolean isEmpty() {
    return end == 0;
  }

  public void insertFirst(EltType first) {
    if(!isEmpty()) {
    EltType[] tempArray;
    tempArray = (EltType[]) new Object[capacity+1];
    for (int i=0;i<deque.length;i++) {
      tempArray[i+1] = deque[i]; 
    }
    deque = tempArray; 
    }
   deque[0] = first;
  }

}

谢谢:)

2 个答案:

答案 0 :(得分:3)

明显的问题是end永远不会改变。 isEmpty()将始终返回true。现在让我们看看你的insertFirst()方法。

public void insertFirst(EltType first) {
    if(!isEmpty()) {
        EltType[] tempArray;
        tempArray = (EltType[]) new Object[capacity+1];
        for (int i=0;i<deque.length;i++) {
            tempArray[i+1] = deque[i]; 
        }

        deque = tempArray; 
    } 
    deque[0] = first;
}

知道isEmpty()总是返回true无论如何,这段代码有什么问题?

答案 1 :(得分:2)

删除元素时,您还需要更新结束指针。

您还应该调查System.arrayCopy()