Сканер выбрасывает исключение java.util.NoSuchElementException при вводе - PullRequest
0 голосов
/ 07 сентября 2018

Приведенный ниже код добавляет NoSuchElementException в функцию aVeryBigSum. PS: это задача от hackerrank, поэтому я могу только изменить код в функции: aVeryBigSum.

Эта функция принимает следующие входные данные: n - это количество элементов в массиве, которые нужно добавить, и элементы массива.

import java.io.*;
import java.math.*;
import java.security.*;
import java.text.*;
import java.util.*;
import java.util.concurrent.*;
import java.util.regex.*;

public class Solution {

    // Complete the aVeryBigSum function below.
    static long aVeryBigSum(long[] ar) {
        int n, sum = 0;
        Scanner read = new Scanner(System.in);
        n = read.nextInt();
        for(int i = 0; i < n; i++)
            sum += read.nextLong();
        return sum;
    }

    private static final Scanner scanner = new Scanner(System.in);

    public static void main(String[] args) throws IOException {
        BufferedWriter bufferedWriter
                = new BufferedWriter(new FileWriter(System.getenv("OUTPUT_PATH")));

        int arCount = scanner.nextInt();
        scanner.skip("(\r\n|[\n\r\u2028\u2029\u0085])?");

        long[] ar = new long[arCount];

        String[] arItems = scanner.nextLine().split(" ");
        scanner.skip("(\r\n|[\n\r\u2028\u2029\u0085])?");

        for (int i = 0; i < arCount; i++) {
            long arItem = Long.parseLong(arItems[i]);
            ar[i] = arItem;
        }

        long result = aVeryBigSum(ar);

        bufferedWriter.write(String.valueOf(result));
        bufferedWriter.newLine();

        bufferedWriter.close();

        scanner.close();
    }
}

Выход: enter image description here

Ответы [ 2 ]

0 голосов
/ 07 сентября 2018
static long aVeryBigSum(long[] ar) {
    int n;
    Long sum = 0;
    Scanner read = new Scanner(System.in);
    n = read.nextInt();
    for(int i = 0; i < n; i++)
        sum += read.nextLong();
    return sum;
}

это нормально работает для меня, если вы измените: int n; длинная сумма = 0; в существующий код и попробуйте.

Выход: 2 1 2

5 1000000001 1000000002 1000000003 1000000004 1000000005 5000000015

0 голосов
/ 07 сентября 2018

Почему вы читаете с Scanner по вашему aVeryBigSum методу?

Просто переберите аргумент ar и вычислите сумму.

static long aVeryBigSum(long[] ar) {
    long _sum = 0;
    for(int i=0; i < ar.length; i++)
        sum += ar[i];
    return _sum;
}
...