Форум программистов, компьютерный форум CyberForum.ru

удаление элументов вектора через итератор - C++

Восстановить пароль Регистрация
 
slipp1
12 / 11 / 1
Регистрация: 09.11.2012
Сообщений: 365
Записей в блоге: 1
27.12.2013, 17:53     удаление элументов вектора через итератор #1
почему так:
C++
1
2
3
4
5
6
//работает
    vector<int>::iterator it=garage.begin();
    while(it!=garage.end())
    {
        it=garage.erase(it);
    }
а так не работает?
C++
1
2
3
4
5
6
//не работает
    vector<int>::reverse_iterator it=garage.rbegin();
    while(it!=garage.rend())
    {
        it=garage.erase(it);
    }
[/CPP]
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
I.M.
 Аватар для I.M.
564 / 547 / 5
Регистрация: 16.12.2011
Сообщений: 1,389
27.12.2013, 18:33     удаление элументов вектора через итератор #2
Типы итераторов разные, а метод erase ждет обычный итератор, а не реверс-итератор.
А почему не std::vector::clear() ? или код просто для описания проблемы
Убежденный
Системный программист
 Аватар для Убежденный
14207 / 6222 / 987
Регистрация: 02.05.2013
Сообщений: 10,367
Завершенные тесты: 1
27.12.2013, 18:44     удаление элументов вектора через итератор #3
Цитата Сообщение от slipp1 Посмотреть сообщение
а так не работает?
Про валидность итераторов не забыли ?
С++, vector modifiers:
iterator erase...

Effects: Invalidates all the iterators and references after the point of the erase.
slipp1
12 / 11 / 1
Регистрация: 09.11.2012
Сообщений: 365
Записей в блоге: 1
27.12.2013, 19:50  [ТС]     удаление элументов вектора через итератор #4
Цитата Сообщение от I.M. Посмотреть сообщение
Типы итераторов разные, а метод erase ждет обычный итератор, а не реверс-итератор.
А почему не std::vector::clear() ? или код просто для описания проблемы
чистит весь вектор:
C++
1
std::vector::clear()
а мне нужно удалить только один элемент

Добавлено через 1 минуту
Цитата Сообщение от Убежденный Посмотреть сообщение
Про валидность итераторов не забыли ?
С++, vector modifiers:
вот так обрабатывается валидность, если яне ошибаюсь...
C++
1
it=garage.erase(it);
проблема в том что обычный итератот работает нормально, а реверстный не компилируется...
OhMyGodSoLong
~ Эврика! ~
 Аватар для OhMyGodSoLong
1234 / 983 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
28.12.2013, 10:58     удаление элументов вектора через итератор #5
Конечно не компилируется, потому что erase() принимает только iterator и const_iterator от вектора. Если вы хотите удалять элементы через reverse_iterator, то такой итератор надо превратить в iterator с помощью метода base(). Только base() возвращает фактически предыдущий элемент с точки зрения reverse_iterator, так что там есть хитрость.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <vector>
#include <iostream>
 
template <class T>
std::ostream& operator<<(std::ostream &stream, const std::vector<T> &vec)
{
    stream << "[";
    if (!vec.empty())
    {
        stream << vec[0];
        for (size_t i = 1; i < vec.size(); i++)
        {
            stream << ", " << vec[i];
        }
    }
    stream << "]";
    return stream;
}
 
int main()
{
    std::vector<int> x = { 1, 2, 3, 4, 5 };
 
    std::cout << x << "\n";
 
    auto it = x.rbegin() + 3;
 
    x.erase((it + 1).base());
 
    std::cout << x << "\n";
}
Yandex
Объявления
28.12.2013, 10:58     удаление элументов вектора через итератор
Ответ Создать тему
Опции темы

Текущее время: 21:38. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru