Какой самый идиоматический способ преобразовать набор целых чисел в набор диапазонов?
например. учитывая набор {0, 1, 2, 3, 4, 7, 8, 9, 11}, я хочу получить {{0,4}, {7,9}, {11,11}}.
Допустим, мы конвертируем из std::set<int>
в std::vector<std::pair<int, int>>
.
Я рассматриваю диапазоны как включающие с обеих сторон, так как в моем случае это более удобно, но я могу работать и с открытыми диапазонами, если это необходимо.
Я написал следующую функцию, но мне хочется заново изобрести колесо.
Пожалуйста, скажите, может быть, есть что-то в STL или повышение для этого.
typedef std::pair<int, int> Range;
void setToRanges(const std::set<int>& indices, std::vector<Range>& ranges)
{
Range r = std::make_pair(-INT_MAX, -INT_MAX);
BOOST_FOREACH(int i, indices)
{
if (i != r.second + 1)
{
if (r.second >= 0) ranges.push_back(r);
r.first = i;
}
r.second = i;
}
ranges.push_back(r);
}