Как в Rust эффективно проверять вхождение индекса (usize) во множество

диапазонов? Диапазоны представлены множеством из Vec<usize>, входные индексы получаются при итерации с помощью enumerate.

11 ответов

16 просмотров

если диапазоны не пересекаются и отсортированы - бинарный поиск, я думаю. остальное - нужно больше информации

Aleksandr-Antonov Автор вопроса
Alexey Ermakov
если диапазоны не пересекаются и отсортированы - б...

Диапазоны отсортированы, но к сожалению пересекаются, и их число ограничено только объёмом оперативной памяти. На входе вектор элементов, диапазоны представлены структурой из имени и вектора Vec<usize>, являются ответами внешнего API. Задача состоит в том, чтобы в один проход по вектору элементов применить логику, параметрами которой является имя диапазона и элемент входного вектора. При этом нужно пройти в том числе по элементам, индексы которых не вошли ни в один диапазон.

Aleksandr Antonov
Диапазоны отсортированы, но к сожалению пересекают...

не очень понимаю как представлены диапазоны типа vec![1, 2, 3], vec![4, 5, 6]?

Aleksandr-Antonov Автор вопроса

struct Range { name: String, range: Vec<usize> } let ranges: Vec<Range>; Диапазон это вектор индексов элементов входного массива, да.

Aleksandr-Antonov Автор вопроса
Алиса Кассель-Королёва
может быть range вида vec![1, 2, 5]?

Нет, я возможно дал некорректное название, но диапазон это именно вектор индексов, где 0 это первый элемент входного вектора.

Aleksandr Antonov
struct Range { name: String, range: Vec<usize>...

То есть на входе могут быть: let range1 = vec![1, 2, 3, 5]; let range2 = vec![3, 4, 6, 7]; И искомый элемент 3, то быстрее чем m*log(n) никак.

Пашечка
То есть на входе могут быть: let range1 = vec![1...

А, или ты именно такие дубли и хочешь найти?

Aleksandr-Antonov Автор вопроса
Пашечка
То есть на входе могут быть: let range1 = vec![1...

3 не является искомым элементом. Задача состоит в том, чтобы в один проход входного вектора эффективно определить, входит ли индекс документа в любой из диапазонов, в один или несколько, и сразу применить логику к элементу для каждого диапазона, в который попал индекс элемента.

Aleksandr Antonov
3 не является искомым элементом. Задача состоит в ...

То есть тебе дали на вход число, например "3" и ты его ищешь в каждом векторе с индексами (которые называешь "диапазонами")? Или я совсем не понимаю задачи

Aleksandr-Antonov Автор вопроса
Пашечка
То есть тебе дали на вход число, например "3" и ты...

Есть входной вектор элементов и вектор векторов индексов, которые возвращает микросервис фильтрации. Нужно эффективно обойти входной вектор элементов, к тем из них, индекс которых имеется в векторах индексов, применить логику, и пойти далее.

Похожие вопросы

Обсуждают сегодня

Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
7
Всем привет. Не понимаю, в чём тут шутка юмора. Убирается только разрешение на send_messages. А send_media_messages остаётся. Как сделать, чтобы оба убирались? await b...
Alexander
2
Есть тут кто занимается разработкой серваков майна? Или знакомые
meow *
3
'frakturBold' => ['𝖆', '𝖇', '𝖈', '𝖉', '𝖊', '𝖋', '𝖌', '𝖍', '𝖎', '𝖏', '𝖐', '𝖑', '𝖒', '𝖓', '𝖔', '𝖕', '𝖖', '𝖗', '𝖘', '𝖙', '𝖚', '𝖛', '𝖜', '𝖝', '𝖞', '𝖟', '𝕬', '𝕭', '𝕮', '𝕯'...
Roma
4
Есть ли лимиты на кол-во вебхук по домену? Стоит в данный момент 900+ ботов и бывает бот перестает отвечать (не приходят вебхуки) 🐒 Помогает только перезапуск
ᅠ [ Кому не ответил, дублируйте ]
11
а что делать если тебя убивают на картах?
Yarik yarik kyda ti lezesh
43
Товарищи, здравствуйте Подскажите, пожалуйста, может кто-нибудь сталкивался с такой задачей Через вебапку можно сканировать qr-код, а есть ли возможность считывать nfc?
Artem Stormageddon
8
Карта сайта