Sobes.tech
Назад к вопросам
Middle+
3

Задачи по Java 1. Напишите реализацию метода: /** * @param a – массив чисел, длина массива может быть больше 10 млн. * @return массив чисел, в которых нету дубликатов. Порядок чисел в оригинальном массиве должен быть сохранён. Из дубликатов нужно оставлять последний элемент, например, для {2,1,4,2,3} правильное решение - {1,4,2,3}, а не {2,1,4,3} В случае, если во входном массиве есть элемент меньше 0, то нужно выдавать ошибку. Например, для {2,3,-1,5} обработка должна закончиться ошибкой. */ public static double[] task(double[] a) { }

Компании, где спрашивали
Мираполис

Ответ от нейросети

sobes.tech AI

Для решения задачи нужно:

  1. Проверить, что в массиве нет отрицательных чисел, иначе выбросить исключение.
  2. Определить для каждого числа его последнее вхождение в массив.
  3. Пройтись по массиву и оставить только те элементы, индекс которых совпадает с последним вхождением.

Так как массив может быть очень большим (более 10 млн элементов), важно использовать эффективные структуры данных и алгоритмы с линейной сложностью.

Пример реализации на Java:

import java.util.*;

public static double[] task(double[] a) {
    // Проверка на отрицательные элементы
    for (double num : a) {
        if (num < 0) {
            throw new IllegalArgumentException("Массив содержит отрицательное число: " + num);
        }
    }

    // Сопоставляем число с его последним индексом
    Map<Double, Integer> lastIndexMap = new HashMap<>();
    for (int i = 0; i < a.length; i++) {
        lastIndexMap.put(a[i], i);
    }

    // Собираем результат, оставляя только элементы, индекс которых совпадает с последним вхождением
    List<Double> resultList = new ArrayList<>();
    for (int i = 0; i < a.length; i++) {
        if (lastIndexMap.get(a[i]) == i) {
            resultList.add(a[i]);
        }
    }

    // Преобразуем список обратно в массив
    double[] result = new double[resultList.size()];
    for (int i = 0; i < result.length; i++) {
        result[i] = resultList.get(i);
    }

    return result;
}

Такой подход сохраняет порядок элементов и оставляет только последние вхождения дубликатов.