Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 10.04.2020
Сообщений: 20

Добавление элемента в список после заданного элемента

19.06.2020, 09:14. Показов 1414. Ответов 0

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

ЛР6.cpp
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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#pragma hdrstop
 
#include "File2.h"
#include "ЛР6.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm7 *Form7;
//---------------------------------------------------------------------------
bool made;
Node *first = NULL;
__fastcall TForm7::TForm7(TComponent* Owner)
: TForm(Owner)
{
}
 
void __fastcall TForm7::Button1Click(TObject *Sender)
{
/* Метод для инициализации списка из одного элемента */
Memo1->Lines->Clear();
first = init(first, &made, Edit1);
outp(first, 1, Memo1);
}
//---------------------------------------------------------------------------
 
void __fastcall TForm7::Button2Click(TObject *Sender)
{ /* Метод для идобавления элемента после заданного */
add(first,Edit3->Text,Edit2);
Memo1->Lines->Clear();
outp(first, 1, Memo1);
}
//---------------------------------------------------------------------------
 
void __fastcall TForm7::Button3Click(TObject *Sender)
{ /* Метод для удаления первого элемента из списка */
dell(first);
Memo1->Lines->Clear();
outp(first, 1, Memo1);
}
//---------------------------------------------------------------------------
 
void __fastcall TForm7::Button4Click(TObject *Sender)
{ /* Метод для удаления списка (освобождение паямяти) */
disp(first);
Close();
}
//---------------------------------------------------------------------------
File2.cpp

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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#include <vcl.h>
#pragma hdrstop
#include "File2.h"
void outp(Node *p, int t, TMemo *mem)
{ /* * * * * * * * * * * * * * * * * * * * * * * *
Вывод списка в окно Mem
p - указатель на первый элемент списка
* * * * * * * * * * * * * * * * * * * * * * * */
Node *q;
q = p;
if(q!=NULL) {
mem->Lines->Add(q->inf);
outp(q->next, t+1, mem);
}
}
Node *init(Node *first, bool *pmade, TEdit *Edt)
{ /* * * * * * * * * * * * * * * * * * * * * * *
Инициализация списка из одного элемента
first - указатель на первый элемент списка
* * * * * * * * * * * * * * * * * * * * * * */
if(*pmade) {
ShowMessage("Список был уже создан ранее!");
return first;
}
if(Edt->Text.IsEmpty()) {
ShowMessage("Неверный ввод! Повторите.");
return NULL;
}
first = new(Node);
first->inf = Edt->Text;
first->next = NULL;
*pmade = true;
return first;
}
void add(Node *first, AnsiString key, TEdit *Edt)
{/*Добавление элемента посел заданного элемента
key - элемент после которого нужно добавить элемент а*/
Node *q,*a;
q=first;
 
while(q!=NULL)
    {
    if (q->inf==key)
        {
        a=new(Node);
        a->inf=Edt->Text;
        if (q->next=NULL)
            {
            q->next=a;
            a->next=NULL;
            }
        else {q->next=a;}
        }
    }
}
void disp(Node *p)
{ /* * * * * * * * * * * * * * * * * * * * * * * *
освобождение памяти из под списка
p - указатель на первый элемент списка
* * * * * * * * * * * * * * * * * * * * * * * */
Node *q, *r;
q = p;
if(q!=NULL) {
r = q->next;
delete q;
disp(r);
}
p = NULL;
}
void dell(Node *&first)
{//Удаление первого элемента
 Node* x=first;
 ShowMessage("Будет удален элемент '" + first->inf + "' Нажми ОК");
 first=first->next;
 delete x;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.06.2020, 09:14
Ответы с готовыми решениями:

В пользовательском классе List (список) реализовать вставку элемента после заданного элемента
Помогите пожалуйста, мне надо сделать вставку элемента после найденного, а у меня элемент добавляется на место первого элемента. ...

Добавление элемента в список после указанного
Добавление нового элемента в список после указанного элемента по значению информационного поля и разбивка списка на два по указанному...

Добавление элемента в линейный список после 1-го, 3-го, 5-го и т.д
Помогите пожалуйста, нужно написать функцию добавления в линейный список заданного элемента после 1-го, 3-го, 5-го и т.д.

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.06.2020, 09:14
Помогаю со студенческими работами здесь

Функция: вставка элемента в двусвязный список после заданного
Всем доброго времени суток! Нужно написать функцию вставки элемента в двусвязный список после заданного. Список моего задания состоит из 4...

Вставка элемента в линейный односвязный список после заданного
Я составила программу, но возникла проблема с реализацией вставки элемента после указанного значения. А точнее с составление функции,...

Линейный односвязный список: реализовать добавление элемента после узла с заданным ключом
Здравствуйте, кто может понять это задание добавление элемента после узла с заданным ключем процедура называется так : Node * insert(Node...

Вставка элемента в заданную позицию, удаление элемента по заданной позиции, поиск заданного элемента
Добавить в класс &quot;Односвязный список&quot; следующие функции: вставка элемента в заданную позицию, удаление элемента по заданной позиции, поиск...

Добавление нового элемента в список после указанного элемента по значению информационного поля
Добавление нового элемента в список после указанного элемента по значению информационного поля.


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru