170 похожих чатов

Задача. Идёт поток проштампованных временем сообщений. Хотя сообщения обычно приходят

в правильном порядке, они могут приходить и в неправильном. Надо их расскладывать сообразно временному порядку. Вопрос. Какую структуру данных для этого имеет смысл применить?

15 ответов

5 просмотров

Зависит от того что с этими сообщениями будет дальше. Навскидку подойдёт priority queue

set

хм... а зачем нам порядок сообщений?

Сортированный вектор? Если неправильный порядок - редкий, то и вставка не в конец будет редкой

поясню: "раскладывать сообразно временному порядку" немного хамелеон внутрь, черный ящик декларирует своё внутреннее устройство, когда должен декларировать внешний интерфейс; если предположить (а) сообщения приходят позже нормы, потому что отдельные сообщения запаздывают (статистически - редко) (б) через много времени, достаточное для прибытия последнего опоздавшего, нас попросят перечислить всех прибывших (в) многопоточности нет то вроде бы правильный ответ такой: держим две очереди, одну обычную, другую PQ (для опоздавших) на выходе выполняем аналог std::merge

Alexander Karaev
Сортированный вектор? Если неправильный порядок - ...

ну вставка в центр это O(n) , а btree это грубо говоря дерево векторов

netricks- Автор вопроса

А чего такого он делает?

netricks
А чего такого он делает?

элементы двигает, разумеется, как вектор

Constantine Drozdov
поясню: "раскладывать сообразно временному порядку...

в общем, this, и можете побенчмаркать - добавление десятка миллионов элементов по одному в порядке возрастания в priority_queue вроде бы сработает быстрее, чем в std::list :)

netricks
А чего такого он делает?

https://github.com/microsoft/STL/blob/52505b9d3249c50b33eb22152a1f18f208ea2959/stl/inc/deque#L1365

netricks- Автор вопроса
netricks- Автор вопроса
Constantine Drozdov
элементы двигает, разумеется, как вектор

Так он же их внутри одного блока только двигает.

netricks
Так он же их внутри одного блока только двигает.

Все двигает. Структура не может вставлять в середину за 1 и находить элемент по индексу за 1

netricks
Так он же их внутри одного блока только двигает.

если не повезет, то будет тупо все двигать

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

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

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
Слушайте, ещё такая интересная задачка. Сделан аудит действий пользователей через триггеры в базе, соответственно каждый пользователь имеет свой логин и пароль в базе. Это пре...
Сергей Бычков
12
Кстати, раз про скачивание файлов разговор зашел) Сделал бота для себя (транскрибирующего и суммаризирующего встречи) но не ожидал что за 2 месяца 10к пользователей набежит😅...
Andrey Obolenskiy
8
вопрос по москвину - не понимаю вот такого вопроса похоже Сколько разных всегда завершающихся функций с типом a -> a -> b -> a -> a можно реализовать? Две функции одинаково...
Fedor
11
Скажите, тут нет проблемы? IMyInterface1 = interface function GetInterface2: IInterface2; ... function TMyInterface.GetInterface2: IInterface2; begin Result := TI...
Ruslan aka DUDE
18
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Утра доброго. Просветите пожалуйста. Хочу сделать rest сервер на делфи. Посмотрел 3 фреймворка: dmvc, Mars, mormot. Ни в одном из них не упоминается ассинхронная обработка вхо...
Сергей Бычков
10
Как попросить stack install делать executable без .exe на винде?
Danila Danko
9
Карта сайта