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

Как создать двусвязный список с использованием шаблона?

30.04.2019, 00:23. Показов 1961. Ответов 5

Студворк — интернет-сервис помощи студентам
Помогите, пожалуйста, разобраться в том, как создать двусвязный список с использованием шаблона в с++. Имею представление, как создавать список для конкретных типов данных. Но нужно создать двусвязный список с использованием шаблона (для начала необходимо просто добавление элементов в этот список)
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.04.2019, 00:23
Ответы с готовыми решениями:

Как создать двусвязный список?
Собственно... не шарю, как сделать двусвязный! односвязный вроде как получается. Двусвязный как-то и не очень :( Конструктор: list() {...

Как создать двусвязный линейный список?
Люди добрые, помогите с лабораторной работой! Нужно выполнить следующее: 3) Двусвязный линейный список. Дополнительные операции: a)...

Создать двусвязный список групп факультета, где каждая группа представляет собой односвязный список студентов
Задание: создайте двусвязный список групп факультета. Каждая группа представляет собой односвязный список студентов. Помогите пожалуйста,...

5
Мозгоправ
 Аватар для L0M
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
01.05.2019, 21:04
Цитата Сообщение от ChelovechK Посмотреть сообщение
Имею представление, как создавать список для конкретных типов данных.
1. Двусвязный список отличается от односвязного наличием в элементе списка второго указателя, который указывает на предыдущий элемент списка.

2. Шаблон, в данном случае, будет использоваться для параметризации типа данных, которые будут в списке. Т.е. это тип "полезной нагрузки".
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
02.05.2019, 06:17
Лучший ответ Сообщение было отмечено ChelovechK как решение

Решение

Цитата Сообщение от ChelovechK Посмотреть сообщение
для начала необходимо просто добавление элементов в этот список
C++
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
template<class T>
struct Elem
{
    Elem* next;
    Elem* prev;
    T data;
};
 
template<class T>
class List
{
    Elem<T>* head;
    Elem<T>* tail;
    size_t size;
public:
    List() :head(nullptr), tail(nullptr), size(0) {}
    List(const List& other) = delete;
    List& operator=(const List& other) = delete;
    ~List() { clear(); }
 
    void push_back(const T& data)
    {
        if (!tail)
            head = tail = new Elem<T>{ nullptr, nullptr, data };
        else
        {
            Elem<T>* p = new Elem<T>{ nullptr, tail, data };
            tail->next = p;
            tail = p;
        }
        ++size;
    }
 
    void clear()
    {
        while (head)
        {
            Elem<T>* p = head;
            head = head->next;
            delete p;
        }
        tail = head;
        size = 0;
    }
};
1
0 / 0 / 0
Регистрация: 30.04.2019
Сообщений: 3
02.05.2019, 19:00  [ТС]
Цитата Сообщение от zayats80888 Посмотреть сообщение
List(const List& other) = delete;
* * List& operator=(const List& other) = delete;
* * ~List() { clear(); }
Спасибо! Вроде бы разобрался. Единственное, не могли бы вы разъяснить, за что отвечают эти строчки?
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
02.05.2019, 19:05
ChelovechK,
C++
1
2
3
List(const List& other) = delete;   // копирующий конструктор (запрещен, если нужно можете определить)
List& operator=(const List& other) = delete; // копирующее присваивание (запрещено, если нужно можете определить)
~List() { clear(); }    // деструктор (освобождаем память)
1
0 / 0 / 0
Регистрация: 30.04.2019
Сообщений: 3
02.05.2019, 21:36  [ТС]
zayats80888, Понял. Благодарю!

Добавлено через 2 часа 26 минут
zayats80888, Видимо мне еще будет необходима ваша помощь. Я немного не понимаю, как мне обращаться с данным списком для конкретного типа данных. То есть например, мне нужно создать 5 интовых элементов. Что мне нужно будет написать в main, чтобы, как это правильно сказать, связать что ли то, что уже есть, к интам?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.05.2019, 21:36
Помогаю со студенческими работами здесь

Создать двусвязный список
Не могу разобраться с двусвязным списком. Вот код списка: #pragma once #include &quot;ClassPhoto.h&quot; struct Node{ Photo...

Создать двусвязный список символов
и удалить из него все буквы y Помогите пожалуйста написать функцию формирования списка, и его считывания до ввода определенного...

Создать двусвязный список с простыми числами
Помогите, пожалуйста, с лабораторной. Задача: Создать двусвязный список с простыми числами. Числа заполнить по следующему алгоритму:...

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

Создать динамический односвязный или двусвязный список
Помогите, как создать динамический односвязный или двусвязный список(Описать структуру). Я не могу понять, чем он отличается от обычного...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
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
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru