- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在阅读一本 Java 算法书。实现队列的方法之一是不使用 nitems 字段来检查队列是空还是满。以下是我正在尝试解决的方法。我尝试通过在白板上绘制数组等来理解这一点,但没有明确的理解。
你们中的任何人都可以解释一下下面的代码吗?感谢您花时间查看此内容。
public boolean isFull() // true if queue is full
{
return ( rear+2==front || (front+maxSize-2==rear) );
}
附加说明:
在这种没有 nelem 的队列实现方式中,数组的大小(即“maxSize”)是(queuesize+1),例如对于 5 个元素的队列大小,maxSize 将为 6。额外的数组元素用于解决队列同时显示为空和满的情况。
其中“rear”字段是数组上的位置,当新元素插入队列时,它会更新,因为队列是 FIFO 的。 “插入新元素时,前面不会更新。
“front”字段是队列中第一个元素的位置,即调用删除方法时将从队列中弹出的元素。
下面是书中的完整算法,以防我的解释不清楚。我想我理解了 isEmpty 方法,但是 isFull 方法对我来说不太清楚。
class Queue
{
private int maxSize;
private long[] queArray;
private int front;
private int rear;
//--------------------------------------------------------------
public Queue(int s) // constructor
{
maxSize = s+1; // array is 1 cell larger
queArray = new long[maxSize]; // than requested
front = 0;
rear = -1;
}
//--------------------------------------------------------------
public void insert(long j) // put item at rear of queue
{
if(rear == maxSize-1)
rear = -1;
queArray[++rear] = j;
}
//--------------------------------------------------------------
public long remove() // take item from front of queue
{
long temp = queArray[front++];
if(front == maxSize)
front = 0;
return temp;
}
//--------------------------------------------------------------
public long peek() // peek at front of queue
{
return queArray[front];
}
//--------------------------------------------------------------
public boolean isEmpty() // true if queue is empty
{
return ( rear+1==front || (front+maxSize-1==rear) );
}
//--------------------------------------------------------------
public boolean isFull() // true if queue is full
{
return ( rear+2==front || (front+maxSize-2==rear) );
}
//--------------------------------------------------------------
public int size() // (assumes queue not empty)
{
if(rear >= front) // contiguous sequence
return rear-front+1;
else // broken sequence
return (maxSize-front) + (rear+1);
}
//--------------------------------------------------------------
} //
谢谢!
拉古
最佳答案
可视化此实现的最佳方法是写下一个测试用例并查看它。假设我们有一个 4 人的队列:
由于此实现是数组的环绕,因此您可以将后部置于前部之前或前部置于后部之前。这就是为什么 isEmpty() 和 isFull() 都有两种情况。我将通过两个示例来演示它 - 一个是我们用 4 个插入填充数组,另一个是 2 个插入、1 个删除、3 个插入、1 个删除和 1 个插入。设 q 为 queArray,r 为后部,f 为前部:
q=[0,0,0,0,0] f=0 r=-1
这是起始位置。此时,在插入之前,队列是空的 - 您可以使用 isEmpty() ,并且条件后+1==前有效,因为 -1+1==0。
q=[5,0,0,0,0] f=0 r=0
第一次插入使后部达到 0。
q=[5,4,0,0,0] f=0 r=1
第二次插入使后部变为 1。
q=[5,4,3,0,0] f=0 r=2
请注意,此时队列已满 - 它包含 4 个元素。调用 isFull() 你会看到条件 front+maxSize-2==rear 为真:0+5-2==3。
现在让我们尝试一下环绕方法,其中后部到达前部后面的索引。让我们从第二个插入开始:
q=[5,4,0,0,0] f=0 r=1
q=[0,4,0,0,0] f=1 r=1
第一个删除。为了这个例子,我实际上将“5”从数组中删除回“0” - 在这个实现中实际上并没有发生,“5”在那里,但在需要时会被覆盖。但对于可视化来说是可行的。
q=[0,4,3,0,0] f=1 r=2
q=[5,0,3,2,1] f=2 r=0
这时候我们终于结束了——rear在front后面,队列中有四个元素!现在看到 isFull() 的另一个条件存在:rear+2==front as 0+2==2。
我希望这有助于说明该解决方案如何工作,而无需实际保留元素计数。
关于Java Queue 的 isFull 方法实现不带 nitems 字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46475434/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!