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

Дратути. Тут есть вопрос для размышлений. Нужно хранилище, в котором данные

отсортированы по значению. При этом оно одинаково интенсивно используется как на чтение(с произвольным доступом по номеру элемента), так и на запись/удаление. Элементы могут совпадать по значению.
Вопрос: на чем бы это следовало делать?
Из моих размышлений:
Массив не очень подходит, поскольку при каждой вставке нужно выполнять смещение элементов после вставляемого. Зато доступ по номеру элемента за О(1).
Бинарное дерево поиска позволяет вставлять в среднем с логарифмической сложностью, но есть проблема с произвольным доступом.
Связный список вообще не подходить.
Я в ступоре.

8 ответов

10 просмотров

Unordered multiset

Heap? Но не поудаляешь/подобавляешь в середину особо

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

У вас, кстати это на одном потоке или многопоточный вариант доступа?

хм вместо бинарного дерева бор использовать?

flat_map?

Вам нужны балансированные бинарные деревья с неявным ключом

Они позволяют хранить "сортированные массивы" со вставкой, удалением, доступом по индексу, все за логарифм, полное перечисление линия

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

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

Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
32
А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Дорогие любители Прекрасной Джулии! Есть кто-то имеющий практический опыт построения ML для Систем Управления? Нам нужно сделать нейросеть для автоматической подстройки пара...
Roman Timo
4
С той же поддержкой Android в тулчейне, если кому интересно. На Swift Forums шло убогое обсуждение всякой херни годами, но ничего годного так и не появлялось. Пришел vgorloff ...
iMike
1
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Приветствую ребята,у меня база есть,прорешал много задач с литкода,там деревья,списки, бэктрэкинг и все остальное,что мне сейчас делать?есть может куда устроиться поработать,е...
Aקuст Lеתסuд Aקuст Lеתסuд
5
Всех приветствую. Направьте меня в нужное русло. Постепенно переписываю проект с delphi на lazarus. Приложение - обычный windows/linux клиент для бд firebird. Тут все хорошо. ...
Mishutka
2
Anybody want this chat app? If anybody interested dm  me.. Note - Firstly payment then i send you code but i will show work on gmeet.
Rayyan Ahmad
5
Карта сайта