Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/21: Рейтинг темы: голосов - 21, средняя оценка - 4.95
0 / 0 / 0
Регистрация: 07.10.2019
Сообщений: 12

Объединение,копирование двусвязного списка

20.12.2019, 15:34. Показов 4356. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго времени суток.
Помогите, пожалуйста, сделать объединение и копирование двусвязного списка.
По копированию, уже есть готовый алгоритм для односвязного списка, а для двусвязного нет.
По объединению, есть вот такой код, но опять же: 1) он для односвязного списка 2) объединение должно быть на месте 2-го списка
Понимаю, что надо где-то хранить предыдущий элемент, но как это правильно сделать- не пойму.
Заранее спасибо!

C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
struct node* CopyList(struct node* head) //функция копирования
{
   struct node* current = head; //первый элемент оригинального списка
   struct node* newList = NULL; //первый элемент нового списка
   struct node* tail = NULL; //последний элемент нового списка
   while (current != NULL) 
   {
      if (newList == NULL)  //создается первый элемент нового списка
      { 
         newList = malloc(sizeof(struct node));
         newList->data = current->data;
         newList->next = NULL;
         tail = newList;
      }
      else 
      {
         tail->next = malloc(sizeof(struct node));
         tail = tail->next;
         tail->data = current->data;
         tail->next = NULL;
      }
      current = current->next;
   }
   return(newList);
}
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
spisok* l3(struct spisok *head1, struct spisok *head2) //объединение двух списков
 
{
 
spisok *t1;
t1 = (struct spisok *) malloc(sizeof(struct spisok));
t1->next = NULL;
t1 = NULL;
spisok *t2;
struct spisok *p;
for (t2 = head1; t2 != NULL; t2 = t2->next)
{
 
p = (struct spisok *) malloc(sizeof(struct spisok));
p->inf = t2->inf;
p->next = t1;
t1 = p;
 
}
 
return t1;
 
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.12.2019, 15:34
Ответы с готовыми решениями:

Даны числа D1 и D2 и указатель P0 на один из элементов непустого двусвязного списка. Добавить в начало списка новый
Даны числа D1 и D2 и указатель P0 на один из элементов непустого двусвязного списка. Добавить в начало списка новый элемент со значением D1...

"Сортировка двусвязного списка путем исключения элемента с минимальным значением и включения его в начало нового списка
Здравствуйте! Возникла проблема с программой. Тема: "Сортировка двусвязного списка путем исключения элемента с минимальным значением и...

Элемент двусвязного списка содержит указатель на строку. Вставить строку в конец списка
Элемент двусвязного списка содержит указатель на строку. Вставить строку в конец списка. В список помещается копия входной строки в...

12
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
20.12.2019, 16:24
Цитата Сообщение от Diggital33 Посмотреть сообщение
Понимаю, что надо где-то хранить предыдущий элемент, но как это правильно сделать- не пойму.
В структуре node
C++
1
2
3
4
5
6
struct node 
{
..........
   node *prev;
   node *next;
};
0
0 / 0 / 0
Регистрация: 07.10.2019
Сообщений: 12
20.12.2019, 21:14  [ТС]
Нет, я не про указатель на предыдущий элемент. Я спрашиваю как именно в методах сделать присваивание предыдущего элемента.
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
20.12.2019, 21:30
Цитата Сообщение от Diggital33 Посмотреть сообщение
Нет, я не про указатель на предыдущий элемент. Я спрашиваю как именно в методах сделать присваивание предыдущего элемента.
Что-то типа
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
struct node* CopyList(struct node* head) //функция копирования
{
    struct node* newList = NULL; //первый элемент нового списка
    struct node* tail = NULL; //последний элемент нового списка
 
    newList = tail = new node;
    newList->data = head->data;
    newList->prev = newList->next = nullptr;
    
    for (head = head->next; head; head = head->next)
    {
        tail->next = new node;
        tail->next->data = head->data;
        tail->next->prev = tail;
        tail = tail->next;
    }
 
    tail->next->next = nullptr;
    return(newList);
}
0
0 / 0 / 0
Регистрация: 07.10.2019
Сообщений: 12
20.12.2019, 21:39  [ТС]
А как можно сделать без двойных стрелок? Просто это немного непонятно для меня.
Заранее спасибо.
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
20.12.2019, 21:46
Цитата Сообщение от Diggital33 Посмотреть сообщение
А как можно сделать без двойных стрелок? Просто это немного непонятно для меня.
C++
1
2
3
4
5
        node *p = new node;
        p->data = head->data;
        p->prev = tail;
        tail->next = p; 
        tail = tail->next;
0
0 / 0 / 0
Регистрация: 07.10.2019
Сообщений: 12
20.12.2019, 21:54  [ТС]
А что делать с 18 строчкой?
tail->next->next = nullptr;
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
20.12.2019, 21:59
Цитата Сообщение от Diggital33 Посмотреть сообщение
А что делать с 18 строчкой?
tail->next->next = nullptr;
tail->next = nullptr;
0
0 / 0 / 0
Регистрация: 07.10.2019
Сообщений: 12
20.12.2019, 22:02  [ТС]
Правильно ли все понял?
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
struct node* CopyList(struct node* head) //функция копирования
{
    struct node* newList = NULL; //первый элемент нового списка
    struct node* tail = NULL; //последний элемент нового списка
 
    newList = tail = new node;
    newList->data = head->data;
    newList->prev = newList->next = nullptr;
    
    for (head = head->next; head; head = head->next)
    {
        node *p = new node;
        p->data = head->data;
        p->prev = tail;
        tail->next = p; 
        tail = tail->next;
    }
 
    tail->next = nullptr;    
    return(newList);
}
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
20.12.2019, 22:04
Цитата Сообщение от Diggital33 Посмотреть сообщение
Правильно ли все понял?
Наверное да, проверь
0
0 / 0 / 0
Регистрация: 07.10.2019
Сообщений: 12
20.12.2019, 22:06  [ТС]
А как быть с объединением? Проблема в том, что должен создаваться не отдельный список, а на месте второго должно происходить объединение.
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
20.12.2019, 22:11
Цитата Сообщение от Diggital33 Посмотреть сообщение
А как быть с объединением? Проблема в том, что должен создаваться не отдельный список, а на месте второго должно происходить объединение.
Находишь последний элемент, его next присваиваешь голове другого списка, а prev этой головы - последнему элементу
0
0 / 0 / 0
Регистрация: 07.10.2019
Сообщений: 12
22.12.2019, 16:06  [ТС]
Не могу разобраться с указателями.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
spisok* l3(struct spisok *head1, struct spisok *head2) //объединение двух списков
 
{
 
spisok *t1;
t1 = (struct spisok *) malloc(sizeof(struct spisok));
t1->next = NULL;
t1->prev = NULL;
t1 = NULL;
spisok *t2;
spisok *p;
for (t2 = head1; t2 != NULL; t2 = t2->next)
{
spisok *p=new spisok;
p->inf=t2->inf;
p->next=t1;
p->prev=???// не понима. что здесь должно быть. И воббще правильно ли я всё сделал выше?
 
}
 
return t1;
 
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.12.2019, 16:06
Помогаю со студенческими работами здесь

Шаблон двусвязного списка
Написала такую программу реализации двусвязного списка.Когда перерабатывала под шаблон,выдает ошибку.Подскажите,в чем проблема? ...

Создание двусвязного списка
Здравствуйте! такая проблема: при задании самой структуры списка, VS находит ошибку в коде, говорит что не поставлена точка с запятой...

Реализация двусвязного списка
Нужно реализовать двусвязный список(с комментариями для чайника ) Добавлено через 13 минут Желательно через template< typename T...

Создание двусвязного списка
Не понимаю как его создать. И как сделать стандартные операции над списком(удаление, добавление и т.д). Сколько сайтов переползал, все...

Cортировка двусвязного списка
Ну, в общем задание в названии. Нужно отсортировать двусвязный список, методом пузырька. Сортировку-то я эту знаю. Но вот проблема, я не...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru