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

Хвост двухсвязанного списка

02.07.2022, 19:51. Показов 668. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Изучаю чужой код. Есть такая структура, описывает двухсвязный список:

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
46
47
48
49
50
51
52
53
54
55
56
template <class TYPE> class List
    {
    struct Node
        {
        Node* pNext;
        Node* pPrev;
        TYPE data;
        Node(Node* pNewPrev,Node* pNewNext)
            : pNext(pNewNext),pPrev(pNewPrev) {}
        };
    Node* m_pHead;
    Node* m_pTail;
    int m_nCount;
public:
    List()
        {
        m_pHead=0;
        m_pTail=0;
        m_nCount=0;
        }
    void RemoveAll();
    ~List() {RemoveAll();}
    TYPE& NewHead();
    TYPE& NewTail();
    void AddHead(TYPE& rData)
        {
        NewHead()=rData;
        }
    void AddTail(TYPE& rData)
        {
        NewTail()=rData;
        }
    Position GetHead() {return (Position)m_pHead;}
    Position GetTail() {return (Position)m_pTail;}
    Position GetNext(Position pos)
        {
        Node* pNode=(Node*)pos;
        if (pNode)
            pNode=pNode->pNext;
        return (Position)pNode;
        }
    Position GetPrev(Position pos)
        {
        Node* pNode=(Node*)pos;
        if (pNode)
            pNode=pNode->pPrev;
        return (Position)pNode;
        }
    void Remove(Position pos);
    TYPE& operator[](Position pos) {return ((Node*)pos)->data;}
    int GetCount() {return m_nCount;}
    bool IsEmpty() {return m_nCount==0;}
    List<TYPE>& operator=(List<TYPE>& rList);
    void Insert(TYPE& rData);
    Position Find(TYPE& rData);
    };
Всю ее изучать не будем, меня интересует только функция:

C++
1
2
3
4
5
6
7
8
9
10
11
template <class TYPE> TYPE& List<TYPE>::NewTail()
    {
    Node* pNode=new Node(m_pTail,0);
    if (m_pTail)
        m_pTail->pNext=pNode; //строчка 1
    else
        m_pHead=pNode;
    m_pTail=pNode; //строчка 2
    ++m_nCount;
    return pNode->data;
    }
Мне не ясно зачем вот эта строчка

C++
1
m_pTail->pNext=pNode; //строчка 1
если то что мы заносим в m_pTail->pNext (т.е. заносим pNode) переписывается переменная m_pTail затем так :

C++
1
m_pTail=pNode; //строчка 2
То есть значение переменной m_pTail переписывается зачем писать "строчка 1" в коде? Для фонаря чисто или что?

Почему нельзя просто написать:

C++
1
2
3
4
5
6
7
8
9
template <class TYPE> TYPE& List<TYPE>::NewTail()
    {
    Node* pNode=new Node(m_pTail,0);
    if (!m_pTail)
        m_pHead=pNode;
    m_pTail=pNode;
    ++m_nCount;
    return pNode->data;
    }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.07.2022, 19:51
Ответы с готовыми решениями:

Игра змейка С++ . Хвост. как создать хвост змейки
День добрый помогите, не знаю как сделать хвост. Код был взят с форума и переделан. Но с хвостом не знаю что делать... буду рад любому...

Прибавить в хвост списка такой элемент, чтобы сумма нового списка была равна S
Подскажите, пожалуйста, в чем ошибка Задание: Прибавить в хвост списка такой элемент, чтобы сумма нового списка была равна S. (defun...

Вставка узла в хвост списка
Мне нужно вставить узел в хвост списка. Я написал функцию вставки, но она не доходит до конца списка. В функцию передаю список и...

6
Гвоздь Задиров
 Аватар для Folian
1718 / 1117 / 337
Регистрация: 25.01.2019
Сообщений: 2,940
02.07.2022, 21:19
Цитата Сообщение от kurlyak Посмотреть сообщение
Для фонаря чисто или что?
Почему нельзя просто написать:
В первом случае pNode добавляется в конец и только потом меняется хвост.
У тебя же хвост просто заменяется новым значением и, очевидно, память протечёт.
1
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
03.07.2022, 02:41
Цитата Сообщение от kurlyak Посмотреть сообщение
Изучаю чужой код. Есть такая структура, описывает двухсвязный список:
Уважаемый Folian ответил раньше.

Поэтому ограничусь советом, что лучше напишите свой код или посмотрите "более лучший" вариант чужого кода.
В этом коде куча плохих практик.
1
14 / 14 / 8
Регистрация: 26.09.2007
Сообщений: 919
03.07.2022, 19:34  [ТС]
Не ясно до конца. Вот эта строчка

C++
1
m_pTail=pNode; //строчка 2
затирает вот это значение m_pTail

C++
1
m_pTail->pNext=pNode; //строчка 1
Если мы поменяем m_pTail

C++
1
m_pTail=pNode; //строчка 2
то по идее затрется m_pTail из

C++
1
m_pTail->pNext=pNode; //строчка 1
и тут m_pTail->pNext будет равен 0 так как за последним элементом ничего нету.
0
Гвоздь Задиров
 Аватар для Folian
1718 / 1117 / 337
Регистрация: 25.01.2019
Сообщений: 2,940
03.07.2022, 19:53
Цитата Сообщение от kurlyak Посмотреть сообщение
Не ясно до конца.
Это указатели.
Миниатюры
Хвост двухсвязанного списка  
2
Гвоздь Задиров
 Аватар для Folian
1718 / 1117 / 337
Регистрация: 25.01.2019
Сообщений: 2,940
03.07.2022, 20:02
Или так. Короч где-то обязательно будет криво будет.
Миниатюры
Хвост двухсвязанного списка  
1
14 / 14 / 8
Регистрация: 26.09.2007
Сообщений: 919
04.07.2022, 17:48  [ТС]
Спасибо огромное! Разобрался!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.07.2022, 17:48
Помогаю со студенческими работами здесь

Если первый и последний элементы списка чётные - то поменять их местами. Иначе поменять местами голову и хвост списка
Дан список. Если первый и последний элементы списка чётные - то поменять их местами. Иначе поменять местами голову и хвост списка. ...

Все положительные элементы, начиная со второго положительного, отправить в хвост списка
Элементы списка нужно вводить с помощью random. Python В списке А=(а1,а2,...,аn) все положительные элементы, начиная со второго...

QuickSort для односвязного и двухсвязанного списков
Помогите пожалуйста,не понимаю,как написать QuickSort для односвязного и двухсвязнного списков. Буду очень благодарен!

Где находится голова и где хвост у односвязного списка
Добрый день и прошу прощения за не совсем полное соответствие разделу. Вопрос по терминологии: допустим есть односвязный список...

Функция, возвращает квадрат аргумента, если аргумент число; хвост списка, если аргумент список; иначе сам аргумент
Помогите, пожалуйста, с заданием: Написать функцию, которая возвращает квадрат аргумента, если аргумент число; хвост списка, если аргумент...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru