Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/25: Рейтинг темы: голосов - 25, средняя оценка - 4.60
4 / 4 / 1
Регистрация: 25.03.2015
Сообщений: 63

Однонаправленный список: как ввести значение в head и последующие узлы списка?

24.09.2016, 15:10. Показов 4927. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В head не хранится значение, не могу добавить информацию в первый элемент, из за чего список является пустым.
Как ввести значение в head и последующие узлы списка? Не могу определить ошибку.


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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#include <iostream>
using namespace std;
const int Size = 30;
struct node {
    char data[Size];
    node* next;
};
 
void addelem(node* head);
//void createk(node* head);
void showlist(node* head);
char menu();
 
void addelem(node* head)
{
    node* h = head;
    node* p = head;
    node* c = head;
    if (head == NULL)
    {
        h = new node;
        cout << "Enter an info: ";
        cin >> h->data;
        head = h;
        c = head;
    }
    else
    {
        while (p->next != NULL)
            p = p->next;
        p = p->next;
        p = new node;
        cout << "Enter an info: ";
        cin >> p->data;
        p->next = NULL;
        c->next = p;
        c = c->next;
    }
}
 
//void createk(node* head)
//{
//
//}
void showlist(node* head)
{
    node* s;
    s = head;
    if (s == NULL)
    {
        cout << "List is empty" << endl;
    }
    else
    {
        while (s != NULL)
        {
            cout << s->data << " ";
            s = s->next;
        }
    }
}
 
char menu()
{
    char choice;
    cout << "1 - Add an element;" << endl
        << "2 - Show a list;" << endl
        << "3 - 'K' condition;" << endl
        << "4 - Quit the program;" << endl
        << "Enter: ";
    cin >> choice;
    return choice;
}
 
 
void main()
{
    node* head = NULL;
    char choice = 0;
    do
    {
        choice = menu();
        switch (choice)
        {
        case '1': addelem(head); break;
        case '2': showlist(head); break;
            //case '3':
        case '4': break;
        default: cout << "Wrong choice." << endl; break;
        }
    } while (choice != '4');
}
Миниатюры
Однонаправленный список: как ввести значение в head и последующие узлы списка?  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.09.2016, 15:10
Ответы с готовыми решениями:

Кольцевой однонаправленный список, вывод списка на экран
Ввод и вывод списка. Ввод вроде работает, а вывод списка не работает, выводится ошибка в этой строке: cout &lt;&lt; pv-&gt; data...

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

Однонаправленный список. Вывод элементов, списка. Удаление списка.
Создать однонаправленный список натуральных чисел. Найти и вывести элементы списка, кратные 3. Удалить из списка все эти элементы и вывести...

14
Helper C/C++
 Аватар для Invader0x7F
286 / 163 / 122
Регистрация: 22.09.2016
Сообщений: 518
24.09.2016, 15:23
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
77
78
79
80
81
82
83
84
#include <iostream>
using namespace std;
const int Size = 30;
struct node {
    char data[Size];
    node* next;
};
 
node* tail = NULL;
 
void addelem(node* head);
//void createk(node* head);
void showlist(node* head);
char menu();
 
void addelem(node* head)
{
       node* h = new node;
       cout << "Enter an info: ";
       cin >> h->data;
 
       if (head == NULL)
       {
           head = h; tail = h;
       }
       else
       {
           tail->next  = h;
           tail = h;
       }
}
 
//void createk(node* head)
//{
//
//}
void showlist(node* head)
{
    node* s;
    s = head;
    if (s == NULL)
    {
        cout << "List is empty" << endl;
    }
    else
    {
        while (s != NULL)
        {
            cout << s->data << " ";
            s = s->next;
        }
    }
}
 
char menu()
{
    char choice;
    cout << "1 - Add an element;" << endl
        << "2 - Show a list;" << endl
        << "3 - 'K' condition;" << endl
        << "4 - Quit the program;" << endl
        << "Enter: ";
    cin >> choice;
    return choice;
}
 
 
void main()
{
    node* head = NULL;
    char choice = 0;
    do
    {
        choice = menu();
        switch (choice)
        {
        case '1': addelem(head); break;
        case '2': showlist(head); break;
            //case '3':
        case '4': break;
        default: cout << "Wrong choice." << endl; break;
        }
    } while (choice != '4');
}
Попробуйте вот-так и обязательно напишите что получилось. Мне самому интересно.
0
4 / 4 / 1
Регистрация: 25.03.2015
Сообщений: 63
24.09.2016, 15:47  [ТС]
Результат тот же, ввожу элемент, показывает что список пустой

Добавлено через 6 минут
Дебаг показал что после ввода элемента значение head остаётся NULL, так что ошибка должна быть в функции добавления элемента, а не в функции просмотра списка
0
Helper C/C++
 Аватар для Invader0x7F
286 / 163 / 122
Регистрация: 22.09.2016
Сообщений: 518
24.09.2016, 15:52
сейчас займусь этим. секундочку.

Добавлено через 2 минуты
А в debug'ере пробовали отслеживать ?? Должно работать.
0
4 / 4 / 1
Регистрация: 25.03.2015
Сообщений: 63
24.09.2016, 15:52  [ТС]
Вот скриншот дебага
Миниатюры
Однонаправленный список: как ввести значение в head и последующие узлы списка?  
0
Helper C/C++
 Аватар для Invader0x7F
286 / 163 / 122
Регистрация: 22.09.2016
Сообщений: 518
24.09.2016, 15:56
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
77
78
79
80
81
82
83
84
85
86
#include <iostream>
using namespace std;
const int Size = 30;
struct node {
    char data[Size];
    node* next;
};
 
node* tail = NULL;
 
void addelem(node* head);
//void createk(node* head);
void showlist(node* head);
char menu();
 
void addelem(node* head)
{
       node* h = new node;
       h->next = NULL;
       cout << "Enter an info: ";
       cin >> h->data;
 
       if (head == NULL)
       {
           head = h; tail = h;
       }
       else
       {
           tail->next  = h;
           tail = h;
       }
}
 
//void createk(node* head)
//{
//
//}
void showlist(node* head)
{
    node* s;
    s = head;
    if (s == NULL)
    {
        cout << "List is empty" << endl;
    }
    else
    {
        while (s != NULL)
        {
            cout << s->data << " ";
            s = s->next;
        }
    }
}
 
char menu()
{
    char choice;
    cout << "1 - Add an element;" << endl
        << "2 - Show a list;" << endl
        << "3 - 'K' condition;" << endl
        << "4 - Quit the program;" << endl
        << "Enter: ";
    cin >> choice;
    return choice;
}
 
 
void main()
{
    node* head = NULL;
    tail = head;
    char choice = 0;
    do
    {
        choice = menu();
        switch (choice)
        {
        case '1': addelem(head); break;
        case '2': showlist(head); break;
            //case '3':
        case '4': break;
        default: cout << "Wrong choice." << endl; break;
        }
    } while (choice != '4');
}
Пробуйте и напишите.
0
4 / 4 / 1
Регистрация: 25.03.2015
Сообщений: 63
24.09.2016, 15:58  [ТС]
В процессе функции head изменился как надо, но когда дебаг прошёл через цикл do-while в main, то значение head было NULL

Добавлено через 1 минуту
то же самое
0
Helper C/C++
 Аватар для Invader0x7F
286 / 163 / 122
Регистрация: 22.09.2016
Сообщений: 518
24.09.2016, 15:59
строка 9:
C++
1
node* head = NULL, tail = NULL;
Попробуйте так.
0
4 / 4 / 1
Регистрация: 25.03.2015
Сообщений: 63
24.09.2016, 16:00  [ТС]
В самой функции head получает значение, которое я ввёл, когда дебаг переходит обратно к main, то значение - NULL

Добавлено через 1 минуту
результат не изменился
0
Helper C/C++
 Аватар для Invader0x7F
286 / 163 / 122
Регистрация: 22.09.2016
Сообщений: 518
24.09.2016, 16:14
Лучший ответ Сообщение было отмечено L1oN как решение

Решение

минуту я занят. проверю напишу.

Добавлено через 10 минут
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
77
78
79
80
81
82
83
84
85
86
#include <iostream>
using namespace std;
const int Size = 30;
struct node {
    char data[Size];
    node* next;
};
 
node* tail = NULL;
 
void addelem(node*& head);
//void createk(node* head);
void showlist(node*& head);
char menu();
 
void addelem(node*& head)
{
    node* h = new node;
    h->next = NULL;
    cout << "Enter an info: ";
    cin >> h->data;
 
    if (head == NULL)
    {
        head = h; tail = h;
    }
    else
    {
        tail->next = h;
        tail = h;
    }
}
 
//void createk(node* head)
//{
//
//}
void showlist(node*& head)
{
    node* s;
    s = head;
    if (s == NULL)
    {
        cout << "List is empty" << endl;
    }
    else
    {
        while (s != NULL)
        {
            cout << s->data << " " << endl;
            s = s->next;
        }
    }
}
 
char menu()
{
    char choice;
    cout << "1 - Add an element;" << endl
        << "2 - Show a list;" << endl
        << "3 - 'K' condition;" << endl
        << "4 - Quit the program;" << endl
        << "Enter: ";
    cin >> choice;
    return choice;
}
 
 
void main()
{
    node* head = NULL;
    tail = head;
    char choice = 0;
    do
    {
        choice = menu();
        switch (choice)
        {
        case '1': addelem(head); break;
        case '2': showlist(head); break;
            //case '3':
        case '4': break;
        default: cout << "Wrong choice." << endl; break;
        }
    } while (choice != '4');
}
1
63 / 61 / 37
Регистрация: 01.04.2015
Сообщений: 116
24.09.2016, 16:16
Как вариант:
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
#include <iostream>
 
using namespace std;
 
const int Size = 30;
 
struct node
{
    char data[Size];
    node* next;
};
 
node* add_elem(node* head)
{
    node* h = new node;
    cout << "Enter an info: ";
    cin >> h->data;
    h->next = head;
    return h;
}
 
void show_list(const node* head)
{
    if (head == NULL) {
        cout << "List is empty" << endl;
    }
    else {
        while (head != NULL) {
            cout << head->data << " ";
            head = head->next;
        }
        cout << endl;
    }
}
 
char menu()
{
    char choice;
    cout << "1 - Add an element;" << endl
        << "2 - Show a list;" << endl
        << "3 - 'K' condition;" << endl
        << "4 - Quit the program;" << endl
        << "Enter: ";
    cin >> choice;
    return choice;
}
 
 
int main()
{
    node* head = NULL;
    char choice = 0;
 
    do {
        choice = menu();
        switch (choice) {
            case '1': head = add_elem(head); break;
            case '2': show_list(head); break;
                //case '3':
            case '4': exit(0);
            default: cout << "Wrong choice." << endl; break;
        }
    } while (choice != '4');
 
    return 0;
}
1
4 / 4 / 1
Регистрация: 25.03.2015
Сообщений: 63
24.09.2016, 16:18  [ТС]
Спасибо, работает, но можете объяснить как? *& позволяет сохранить изменения по адресу в функции после её выполнения?
0
Helper C/C++
 Аватар для Invader0x7F
286 / 163 / 122
Регистрация: 22.09.2016
Сообщений: 518
24.09.2016, 16:19
& - это ссылка (reference). я сейчас занят. позднее объясню.
0
4 / 4 / 1
Регистрация: 25.03.2015
Сообщений: 63
24.09.2016, 16:20  [ТС]
не надо, я почитаю, спасибо за помощь
0
62 / 62 / 55
Регистрация: 18.10.2014
Сообщений: 190
24.09.2016, 16:41
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
77
78
79
#include <iostream>
using namespace std;
const int Size = 30;
struct node {
    char data[Size];
    node* next;
};
node* tail = NULL;
void addelem(node* head);
void showlist(node* head);
char menu();
void addelem(node** head)
{
       node* h = new node;
       cout << "Enter an info: ";
       cin >> h->data;
       if ((*head) == NULL)
       {
           *head=new node;
           (*head)->next=NULL;
           for(int i=0;i<Size;i++)
           (*head)->data[i] = h->data[i]; 
           tail = *head;
       }
       else
       {
           tail->next  = new node;
           tail = tail->next;
           tail->next=NULL;
           for(int i=0;i<Size;i++)
           tail->data[i] = h->data[i]; 
       }
}
void showlist(node* head)
{
    node* s;
    s = head;
    if (s == NULL)
    {
        cout << "List is empty" << endl;
    }
    else
    {
        while (s != NULL)
        {
            cout << s->data << " ";
            s = s->next;
        }
    }
}
 
char menu()
{
    char choice;
    cout << "1 - Add an element;" << endl
        << "2 - Show a list;" << endl
        << "3 - 'K' condition;" << endl
        << "4 - Quit the program;" << endl
        << "Enter: ";
    cin >> choice;
    return choice;
}
void main()
{
    node* head = NULL;
    char choice = 0;
    do
    {
        choice = menu();
        switch (choice)
        {
        case '1': addelem(&head); break;
        case '2': showlist(head); break;
        case '4': break;
        default: cout << "Wrong choice." << endl; break;
        }
    } while (choice != '4');
    system("pause");
}
Забыл про списки, но в общем когда если у нас изначально создано указатель , т.е head в main'е указатель, то передавая его в функцию он изменятся не будет функция должна принимать указатель на указатель.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.09.2016, 16:41
Помогаю со студенческими работами здесь

Динамический однонаправленный список. Удаление элементов из списка.
входные данные : 3 ---количество студентов Ivan Roman Yura Yura --- студент,которого нужно...

Линейно-однонаправленный список (удалить элемент списка по ключу)
Нужна помощь с методом удаление,должен удалить элемент списка по ключу,поиск приведён. #include &lt;iostream.h&gt; #include...

Однонаправленный список из квадратов отрицательных элементов первого списка
Создать однонаправленный список действительных чисел, который может содержать как положительные так и отрицательные числа. Создать...

Однонаправленный список элементов (удвоить каждый элемент списка)
Сформировать однонаправленный список элементов типа char и написать программу следующих операций над ним: а) удвоить каждый элемент списка.

Список: Взять исходный список SP и создать два новых списка SP1 и SP2. SP1 содержит нечетные узлы, а SP2 – четные
Что-то карета не вывезла и превратилась в тыкву. не могу понять почему данные не записывают в SP2 не понимаю почему в SP1 только...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
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 - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru