Просмотр, пропускающий похожие соседние элементыC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Просмотр, пропускающий похожие соседние элементы

Сообщение Anonymous »

Функция std::ranges::unique позволяет удалять одинаковые соседние элементы, например

Код: Выделить всё

#include 
#include 

int main()
{
std::vector v {1, 2, 1, 1, 3, 3, 3, 4, 5, 4};
fmt::println ("{}", v);
// [1, 2, 1, 1, 3, 3, 3, 4, 5, 4]

const auto ret = std::ranges::unique(v);
v.erase(ret.begin(), ret.end());
fmt::println ("{}", v);
// [1, 2, 1, 3, 4, 5, 4]
}
Однако это разрушительный процесс для вектора v. Я хотел бы использовать представление, которое пропускает аналогичные соседние элементы, не разрушая вектор, т.е. что-то вроде:

Код: Выделить всё

auto vw = v | skip_adjacent_items;
fmt::println ("{}", vw);
// [1, 2, 1, 3, 4, 5, 4]
Есть ли что-то подобное в std, в частности в части std::views?
Самое близкое, что я вижу, это std::views::filter, но он фильтрует элемент независимо от предыдущего итерированного элемента.>

Подробнее здесь: https://stackoverflow.com/questions/798 ... cent-items
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»