首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >循环数组队列

循环数组队列
EN

Stack Overflow用户
提问于 2012-10-16 00:36:27
回答 1查看 4.7K关注 0票数 0

我正在尝试实现一个没有count变量的循环数组队列。

我正在寻找一种方法来确定数组是否已满,以便它调用expand方法,但它似乎无法工作,这是为什么?谢谢!

代码语言:javascript
复制
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;
    }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-10-16 01:02:35

我发现的第一个错误是,在需要扩展的情况下,您从来没有向队列中添加任何内容!enqueue方法需要如下所示:

代码语言:javascript
复制
public void enqueue(T element) {
    if (front == (rear + 1) % queue.length) {
        expandCapacity();
    }
    queue[rear] = element;
    rear = (rear + 1) % queue.length;
}

此外,在expandCapacity中,您将rear设置为比您应该设置的大1;

代码语言:javascript
复制
    rear = queue.length - 1;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12900044

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档