Назад к вопросам
Middle
100
questionbank

Как выполнить операцию удаления элемента из начала в векторе, если порядок элементов не важен?

Sobes Copilot

Получайте ответы в реальном времени

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

sobes.tech AI

Эффективный способ - переместить последний элемент вектора в начало и затем удалить последний элемент.

#include <vector>
#include <algorithm> // Для std::swap

int main() {
    std::vector<int> vec = {1, 2, 3, 4, 5};

    if (!vec.empty()) {
        std::swap(vec.front(), vec.back()); // Перемещаем последний элемент в начало
        vec.pop_back();                  // Удаляем последний (теперь исходный первый) элемент
    }

    // vec теперь без исходного первого элемента, порядок неважен.

    return 0;
}

Этот подход имеет сложность O(1), в отличие от O(n), которое было бы при использовании vec.erase(vec.begin()).