std::set
. Изначально искал нужный элемент через
auto for_delete = std::set::find(...)
, после чего хотел передать в
std::set::erase(for_delete, set::end())
, но типы у итераторов разные, так как поиск идёт по бинарному дереву (
std::_Rb_tree_const_iterator), а set::end
просто
std::set::iterator
. Как лучше поступить в таком случае? Думал reinterpret_cast использовать, но как-то не уверен, что так норм
Не разные там типы
Ну там нет определения срвнения между этими итераторами: error: no match for ‘operator<’ (operand types are ‘std::_Rb_tree_const_iterator<std::pair<double, int> >’ and ‘std::set<std::pair<double, int> >::iterator {aka std::_Rb_tree_const_iterator<std::pair<double, int> >}’) Норм ли будет его просто дописать? Или всё же использовать каст?
https://godbolt.org/z/o31cTWq7Y Все отлично работает И по сообщению об ошибке видно, что итераторы одного типа. Так что косяк где-то в коде, нужен весь код
Я затупил и не заметил, что у меня изначально не компилится условие сравнения этих итераторов: https://godbolt.org/z/vdxW95TTE
Обсуждают сегодня