カウント変数なしで循環配列キューを実装しようとしています。
expand メソッドを呼び出すために、配列がいっぱいかどうかを判断する方法を探していますが、なぜうまくいかないようですか? ありがとう!
public void enqueue (T element) {
if(front != (rear+1) % queue.length) {
queue[rear] = element;
rear = (rear+1) % queue.length;
}
else
expandCapacity();
}
public void expandCapacity() {
T[] larger = ((T[]) (new Object[queue.length * 2]));
for (int scan=0; scan < queue.length; scan++) {
larger[scan] = queue[front];
front = (front+1) % queue.length;
}
front = 0;
rear = queue.length;
queue = larger;
}