Назад к вопросам
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
Для решения задачи нужно:
- Проверить, что в массиве нет отрицательных чисел, иначе выбросить исключение.
- Определить для каждого числа его последнее вхождение в массив.
- Пройтись по массиву и оставить только те элементы, индекс которых совпадает с последним вхождением.
Так как массив может быть очень большим (более 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;
}
Такой подход сохраняет порядок элементов и оставляет только последние вхождения дубликатов.