|
0 / 0 / 0
Регистрация: 22.11.2015
Сообщений: 12
|
|||||||||||
Слияние отсортированных массивов максимально эффективно25.08.2018, 13:44. Показов 4357. Ответов 6
Здравствуйте! По условию задачи есть два отсортированных по возрастанию массива.
То есть сигнатура метода выглядит таким образом:
То есть ответ мы должны записать в a. Причём сложность должна быть o (n)! Вот моё решение:
Реализовать сложность o (n) мне удалось только сделав вот этот алгоритм. http://sashkoblog.blogspot.com... st_16.html Но при таком подходе, увы, приходится создать новый массив. Надеюсь на вашу помощь! Вариант, что такое невозможно, меня устроит. Главное чтобы я не один так считал Но всё таки не перестаю сдаваться.
0
|
|||||||||||
| 25.08.2018, 13:44 | |
|
Ответы с готовыми решениями:
6
Слияние отсортированных массивов
Слияние двух отсортированных массивов в третий |
|
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
|
||
| 25.08.2018, 15:14 | ||
a.Без выделения дополнительной памяти можно поменять элементы в этих двух массивах так, чтобы меньшие были в a, а большие оказались в b. Потребуется вставка элемента в середину массива со сдвигом последующих элементов, поэтому сложность будет O(n*m), но дополнительной памяти потребуется O(1).
1
|
||
|
0 / 0 / 0
Регистрация: 22.11.2015
Сообщений: 12
|
|
| 25.08.2018, 16:21 [ТС] | |
|
То есть получается что нельзя добиться, чтобы выделение памяти было O(1) и при этом сложность получилась O(n). Ведь ваш вариант предполагает O(n*m), что по сути и есть n^2.
0
|
|
|
Модератор
3135 / 2282 / 469
Регистрация: 26.03.2015
Сообщений: 8,884
|
|||
| 25.08.2018, 19:06 | |||
|
Добавлено через 3 минуты
0
|
|||
|
0 / 0 / 0
Регистрация: 22.11.2015
Сообщений: 12
|
|||||||
| 25.08.2018, 21:00 [ТС] | |||||||
|
Я не пытаюсь записать в массив размера N массив N+M. Я пытаюсь придумать, чтобы использовать массив A добавив в него элементы из B. Не создавая третий массив, в который будут сливаться элементы и A и из B. Вот например как в этом решении:
http://www.pvsm.ru/java/118071
0
|
|||||||
|
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
|
||
| 25.08.2018, 21:24 | ||
|
Ситуация типичная — либо используем дополнительную память и экономим операции, либо экономим память, но проигрываем по операциям. Выиграть по всем параметрам в этой задаче, скорее всего, не получится, а решение из первого поста проигрывает по обоим. Еще можно вместо массивов использовать списки, тогда вставка элементов в середину будет дешевле.
1
|
||
|
0 / 0 / 0
Регистрация: 22.11.2015
Сообщений: 12
|
|
| 25.08.2018, 21:34 [ТС] | |
|
Я понял, спасибо вам! Видимо, LinkedList - будет единственно возможным вариантом в такой ситуации, так как вставка производится за время O(1). Тогда первое решение будет выигрывать хотя бы по скорости. Так как теперь не будут копироваться элементы
0
|
|
| 25.08.2018, 21:34 | |
|
Помогаю со студенческими работами здесь
7
Слияние отсортированных последовательностей
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|