Форум программистов, компьютерный форум, киберфорум
Алгоритмы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22

Копирование односвязного линейного списка

08.07.2018, 18:54. Показов 2412. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан список, каждый узел которого в качестве данных имеет другой указатель на узел, причем известно, что он
указывает на какой-то элемент того же списка. Требуется построить копию данного списка, в которой дополнительный
указатель на узел («данные») указывает на узел копии с тем же номером в копии, с каким указатель в оригинале
для данного узла указывал на элемент исходного списка (за линейное время, на константной памяти, кроме заведения
копий узлов).
Можете дать подсказку того в каком направлении думать? Непонимание реализации именно в этом:
узел которого в качестве данных имеет другой указатель на узел, причем известно, что он
указывает на какой-то элемент того же списка
1
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.07.2018, 18:54
Ответы с готовыми решениями:

Распечатка односвязного списка в обратном порядке
Услышал, через много рук, условие задачи, заданной парню на собеседовании. Мучает вопрос уже вторые сутки, уснуть не могу. Такое ощущение,...

Создание линейного односвязного списка
-найти произведение элементов списка. -вывести на экран нечетные элементы списка.

Ввод вложенного односвязного линейного списка
Помогите, пожалуйста разобраться с вводом вложенного односвязного линейного списка. Вот хотя бы на таком примере структур: struct...

5
Эксперт функциональных языков программированияЭксперт по математике/физике
4313 / 2105 / 431
Регистрация: 19.07.2009
Сообщений: 3,204
Записей в блоге: 24
08.07.2018, 22:58
Односвязный список состоит из узлов, причём каждый узел является парой из ссылки на следующий узел и данных.
В рассматриваемой задаче вторая компонента узла (данные) также является указателем, причём то, на что он указывает, во всех случаях также является узлом некоторого списка.
Проще говоря, в этой задаче узел - это пара из двух указателей, а все рассматриваемые указатели указывают исключительно на какие-то узлы.

Односвязный список есть первый его узел. Рекурсивно определяется множество узлов списка. Каждый узел состоит из двух указателей. Один из них указывает на "следующий" узел. А второй...
Цитата Сообщение от Volobuev Ilya Посмотреть сообщение
узел которого в качестве данных имеет другой указатель на узел, причем известно, что он
указывает на какой-то элемент того же списка
указывает на какой-то узел этого же списка. Может, на себя. Может, на следующий. Может, на первый.

Насколько я понимаю, стоит задача создать другой список, множество узлов которого было бы равномощным (взаимооднозначно соответствующим) исходному. Обе ссылки каждого узла A нового списка должны указывать на узлы нового списка, соответствующие узлам старого списка, на которые указывают указатели узла-праобраза A старого списка.

Все остальные обсуждения, как мне кажется, следует сопровождать иллюстрациями с двумя изоморфными непересекающимися графами узлов. Рисуйте.
1
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
09.07.2018, 00:06  [ТС]
Mysterious Light, я думаю что при создании копии списка следует где то хранить ссылки (которые лежат в информационных полях узлов списка). Только вот где и как...
0
294 / 265 / 48
Регистрация: 09.04.2013
Сообщений: 1,038
09.07.2018, 11:30
Лучший ответ Сообщение было отмечено OwenGlendower как решение

Решение

делаешь в два шага
1) создать список того же размера но с пустым полем данных
2) делаешь двойной цикл прохода по двум очередям одновременно, в первом цикле берешь данные из ячейки первой очереди, во втором цикле находишь куда ссылка из данных указывает и записываешь соответствующую ссылку в данные в ячейке второй очереди.
1
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
09.07.2018, 17:08  [ТС]
wingblack, не списки, а именно очереди?
0
294 / 265 / 48
Регистрация: 09.04.2013
Сообщений: 1,038
10.07.2018, 09:22
Цитата Сообщение от Volobuev Ilya Посмотреть сообщение
wingblack, не списки, а именно очереди?
Ошибся, списки конечно.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.07.2018, 09:22
Помогаю со студенческими работами здесь

Гайд по сортировке односвязного линейного списка
Посоветуйте пожалуйста толковый гайд по сортировке. Уже столько всего перерыл, прочитал, но понять алгоритм не получается Добавлено...

Сортировка односвязного линейного списка по алфавиту
Всем здравствуйте! Имеется линейный список. Помогите, пожалуйста, написать сортировку студентов этого списка по фамилии. То есть, в...

Проход по элементам односвязного линейного списка
Допустим у меня существует класс линейного односвязного списка. Надо пройти по его элементам и присвоить каждому соответствующее...

Найти наименьший элемент односвязного линейного списка
Найти наименьший элемент односвязного линейного списка. Сценарий: обходя список найти минимальное значение поля Data. Прошу помогите, ума...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru