![]() |
1. Заголовок или название темы должно быть информативным !
2. Все тексты фрагментов программ должны помещаться в теги [code] ... [/code] или [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ" и используйте ПОИСК !
4. НЕ используйте форум для личного общения!
5. Самое главное - это раздел теоретический, т.е. никаких задач и программ (за исключением небольших фрагментов) - для этого есть отдельный раздел!
![]() |
krilov |
![]() ![]()
Сообщение
#1
|
Группа: Пользователи Сообщений: 5 Пол: Мужской Репутация: ![]() ![]() ![]() |
Нет ли способа вставить в отсортированный массив новый элемент за O(log n)?[size=3]
|
![]() ![]() |
hardcase |
![]()
Сообщение
#2
|
![]() code warrior ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 484 Пол: Мужской Реальное имя: Славен Репутация: ![]() ![]() ![]() |
А ты Красно-Чёрные деревья пробовал, ну или АВЛ-деревья?
Думаю должно прокатить, вот только я не помню время вставки-удаления. А вот ещё вариант: у нас есть уже отсортированный массив чисел. При сумме двух минимальных мы пытаемся найти вхождение этого числа в массив - если не находим, то добавляем в список, ассоциированный с ближайшим меньшим/большим числом (соответственно список тоже должен быть отсортированным). В противном случае (если вхождение нашли) то инкрементим счётчик вхождений данного числа. По моему это будет эффективно и должны уложиться в О(н*Лог(н)). -------------------- ИзВ ин ИтЕ зА нЕ рОв НЫй П оч ЕРк
|
![]() ![]() |
![]() |
Текстовая версия | 22.06.2025 1:11 |