функциональная спецификация
В отсортированном массиве (или векторе) Найдите самые длинные последовательности повторяющихся значений. Ожидается, что размер массива будет относительно большим (до миллиона записей).
Пожалуйста, посмотрите полностью функциональную демонстрацию. Только не хочу переполнять здесь вещи. Что-то вроде простого одной однострочной решения. Обратите внимание, что это предоставляется только для объяснения в коде того, что я хочу иметь в функциональной спецификации. Не сосредотачивайтесь на этом. И если вы готовы предложить улучшения, обратите внимание, что производительность, если не ключ, но имеет значение; Поэтому, пожалуйста, не предлагайте решения с сбором большого количества данных в картах или других динамических структурах. Мой вопрос только о простом однострочном решении.#include
#include
#include
std::pair get_longest_ranges(auto first, auto last)
{
ptrdiff_t max_range = 0;
size_t amount_of_ranges = 0;
auto it = first;
while (it != last) {
auto it_end = std::upper_bound(it, last, *it);
if (max_range == it_end - it) {
++amount_of_ranges;
} else if (max_range < it_end - it) {
max_range = it_end - it;
amount_of_ranges = 1;
}
it = it_end;
}
std::vector ranges;
ranges.reserve(amount_of_ranges);
it = first;
while (it != last) {
auto it_end = std::upper_bound(it, last, *it);
if (it_end - it == max_range) {
ranges.push_back(it-first);
}
it = it_end;
}
return { ranges, max_range };
}
int main() {
std::vector v = { 1, 1, 1, 2, 2, 2, 2, 3, 3, 4, 4, 5, 6, 6, 6, 7, 7, 7, 7 };
auto [starts, length] = get_longest_ranges(v.begin(),v.end());
std::cout
Подробнее здесь: https://stackoverflow.com/questions/779 ... ces-of-rep
Существует ли алгоритм ЗППП или их комбинация, чтобы найти самые длинные последовательности повторяющихся значений в отс ⇐ C++
Программы на C++. Форум разработчиков
1750019409
Anonymous
[b] функциональная спецификация [/b]
В отсортированном массиве (или векторе) Найдите самые длинные последовательности повторяющихся значений. Ожидается, что размер массива будет относительно большим (до миллиона записей).
Пожалуйста, посмотрите полностью функциональную демонстрацию. Только не хочу переполнять здесь вещи. Что-то вроде простого одной однострочной решения. Обратите внимание, что это предоставляется только для объяснения в коде того, что я хочу иметь в функциональной спецификации. Не сосредотачивайтесь на этом. И если вы готовы предложить улучшения, обратите внимание, что производительность, если не ключ, но имеет значение; Поэтому, пожалуйста, не предлагайте решения с сбором большого количества данных в картах или других динамических структурах. Мой вопрос только о простом однострочном решении.#include
#include
#include
std::pair get_longest_ranges(auto first, auto last)
{
ptrdiff_t max_range = 0;
size_t amount_of_ranges = 0;
auto it = first;
while (it != last) {
auto it_end = std::upper_bound(it, last, *it);
if (max_range == it_end - it) {
++amount_of_ranges;
} else if (max_range < it_end - it) {
max_range = it_end - it;
amount_of_ranges = 1;
}
it = it_end;
}
std::vector ranges;
ranges.reserve(amount_of_ranges);
it = first;
while (it != last) {
auto it_end = std::upper_bound(it, last, *it);
if (it_end - it == max_range) {
ranges.push_back(it-first);
}
it = it_end;
}
return { ranges, max_range };
}
int main() {
std::vector v = { 1, 1, 1, 2, 2, 2, 2, 3, 3, 4, 4, 5, 6, 6, 6, 7, 7, 7, 7 };
auto [starts, length] = get_longest_ranges(v.begin(),v.end());
std::cout
Подробнее здесь: [url]https://stackoverflow.com/questions/77950050/is-there-std-algorithm-or-their-combination-to-find-the-longest-sequences-of-rep[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия