- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试复制原始队列并打印出队列的内容,然后再次运行副本并打印队列中的元素总数。当我在原始队列上运行 CopyQueue 方法并将其用作 ShowQueue 方法的输入时,它会更改原始队列。
public static void main(String[] args) {
LinkedUnbndQueue test = new LinkedUnbndQueue();
test.enqueue('a');
test.enqueue('b');
System.out.println( showQueue(CopyQueue(test)) );
System.out.println( Count(CopyQueue(test)) );
}
public static LinkedUnbndQueue CopyQueue(LinkedUnbndQueue orig){
LinkedUnbndQueue copy = orig;
return copy;
}
public static int Count(LinkedUnbndQueue orig){
int count = 0;
while(!orig.isEmpty() ){
orig.dequeue();
count = count + 1;
}
return count;
}
public static String showQueue(LinkedUnbndQueue orig){
String str = "";
while(!orig.isEmpty()){
str = str + orig.dequeue() + " ";
}
return str;
}
最佳答案
您的方法 CopyQueue 完全错误。您正在使用别名而不是复制队列的内容。
当你这样做时:
public static LinkedUnbndQueue CopyQueue(LinkedUnbndQueue orig){
LinkedUnbndQueue copy = orig;
return copy;
}
您将返回一个指向同一原始队列的指针。如果要复制队列,则需要复制新结构中的所有元素,例如:
public static LinkedUnbndQueue CopyQueue(LinkedUnbndQueue orig){
LinkedUnbndQueue copy = new LinkedUnbndQueue();
for(Object o : orig){
copy.add(o);
}
return copy;
}
关于java - 复制 LinkedQueue,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15398566/
我正在尝试复制原始队列并打印出队列的内容,然后再次运行副本并打印队列中的元素总数。当我在原始队列上运行 CopyQueue 方法并将其用作 ShowQueue 方法的输入时,它会更改原始队列。 pub
我想知道哪个是使用 EDU.oswego.cs.dl.util.concurrent.LinkedQueue 的最佳替代方案。 在以下情况下: public class testQueue exten
首先,我想说这是我在这里发表的第一篇文章,所以如果我做错了什么,请告诉我。 我有一个名为 EmployeeRecord 的类: void setEmployeeRecord(int empNo, St
我用Java实现了一个LinkedQueue。这是我自己的实现,它不扩展任何类或实现任何接口(interface)(项目的要求)但是,我的打印方法没有返回队列中的第一项。有什么想法吗? ListNod
我正在尝试用 C++ 实现一个 LinkedQueue 结构来存储一些航类的数据。 所以,首先我必须读取一个 csv 文件,它提供了要存储的数据。LinkedQueue 必须以这种方式工作:必须使用
我只是在寻找一个技巧来帮助我开始这个程序,这样我就可以有多个“行”。我目前有 1 行,正在尝试添加另外两行(LinkedQueues)。我需要编写一个包含 3 行的程序。而不是只有一行。我只是在寻找一
我是 C++ 的新手。我正在研究 here 中的以下示例.我得到 expected a declaration行错误 friend LinkedQueue; .我的理解是我需要使用类似 friend
通过这个 LinkedQueue 的实现,除了 pop() 方法之外的所有方法都可以正常工作。当使用 pop() 方法时,堆栈中的所有值都会消失,当它应该只删除第一个值时,堆栈会变成空 这是 Link
我是一名优秀的程序员,十分优秀!