首页 > 解决方案 > ArrayDeque<>(int capacity) - Scanner.nextInt() == 4 和 (int) 4 有什么区别?

问题描述

任务是编写一个读取数字并将它们存储到双端队列的程序。

样本输入为: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 。即这是不正确的。

为什么以不同方式输入相同容量会产生如此不同的结果?

标签: javacollectionsarraydeque

解决方案


这与你如何通过容量没有太大关系。Scanner.nextInt它与循环内调用多少次有关。

因为总是有 5 个输入,第一个输入总是大小,如果你这样做

Deque<Integer> deque = new ArrayDeque<>(sc.nextInt()) 

sc.nextInt总共会被调用 5 次(因为你有 5 个输入),在循环中调用 4 次,在上面的行中调用 1 次,因此将向双端队列添加 4 个数字。这是对的。

但是,如果您这样做:

Deque<Integer> deque = new ArrayDeque<>(4)

sc.nextInt将在循环内被调用 5 次,因此将向双端队列添加 5 个数字。但是第一个数字实际上不应该添加到双端队列中,因为它是大小,因此会产生错误的输出。

ArrayDeque可调整大小,因此您实际上不需要指定大小,您的代码仍然可以工作。

sc.nextInt您可以通过在循环之前调用来忽略第一个输入:

sc.nextInt();
while (sc.hasNextInt()) {
   ...

推荐阅读