任务是编写一个读取数字并将它们存储到双端队列的程序。
样本输入为:4 1 2 3 4 样本输出:4 2 1 3
偶数应该作为第一个元素,奇数 - 作为最后一个元素。之后,程序必须输出从第一个到最后一个的所有元素。
这是我的一段代码:
import java.util.ArrayDeque;
import java.util.Deque;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
Deque<Integer> deque = new ArrayDeque<>(sc.nextInt());
while (sc.hasNext()) {
int nextInt = sc.nextInt();
if (nextInt % 2 == 0) {
deque.addFirst(nextInt);
} else deque.addLast(nextInt);
}
for (int elt : deque) {
System.out.println(elt);
}
}
}
样本输出:4 2 1 3
它工作正常,它是正确的。但!
让我们重写
Deque<Integer> deque = new ArrayDeque<>(sc.nextInt())
作为
Deque<Integer> deque = new ArrayDeque<>(4)
对于这个,样本输出是: 4 2 4 1 3 。即这是不正确的。
为什么以不同方式输入相同容量会产生如此不同的结果?