Back to questions
Junior — Middle
75
Как определить временные затраты при добавлении элемента в ArrayList?
Companies where asked
Ifellow
Answer from AI
sobes.tech AI
Временные затраты при добавлении элемента в ArrayList зависят от того, есть ли в списке достаточно места для нового элемента. Если внутренний массив ArrayList не заполнен, добавление происходит за амортизированное время O(1), так как элемент просто помещается в следующую свободную ячейку.
Если же массив заполнен, происходит его расширение: создаётся новый массив большего размера (обычно в 1.5–2 раза больше), и все элементы копируются в него. Это занимает время O(n), где n — текущий размер списка. Однако такие операции происходят редко, поэтому среднее время добавления остаётся близким к O(1).
Пример:
ArrayList<Integer> list = new ArrayList<>();
list.add(10); // Быстрое добавление, если места достаточно