Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
13 / 17 / 6
Регистрация: 05.09.2012
Сообщений: 210

Значения не вставляются в начало списка

21.02.2013, 19:42. Показов 623. Ответов 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
57
58
59
60
61
62
63
#include <iostream>
using namespace std;
 
struct Node
{
    char data;
    Node *next;
};
 
 
Node *add_last(Node *last,char data)
{   
    if(last == NULL)
    {
        last = new Node;
    }
    else
    {
        last->next = new Node;
        last = last->next;
    }
    last->data = data;
    last->next = NULL;
    return last;
}
 
Node *add_first(Node *&first,char data)
{
    Node *first_insert = new Node;
    first_insert->data = data;
    first_insert->next = first;
    first_insert = first_insert->next;
    return first_insert;
}
 
void show(Node *first)
{   
    while(first != NULL)
    {
        cout <<first->data<<endl;
        first = first->next;
    }
}
 
int main(int argc, char const *argv[])
{
    Node *first, *last;
    first = last = NULL;
 
    if(first == NULL)
    {
        first = add_last(last,'c');
        last = first;
    }
    else
    {
        last = add_last(last,'c');
    }
 
    first = add_first(first,'b');
    show(first);
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.02.2013, 19:42
Ответы с готовыми решениями:

Создание списка, печать списка на экран, добавления элемента в начало списка, конец списка
Построить динамическую структуру типа список . Необходимо реализовать следующие процедуры: 1. создание списка. 2. печать списка на...

Не вставляются значения
Почему-то не вставляются значения $title и $content в input Вырезки из файлов: function articles_get($id_article) { //...

В БД вставляются некорректные значения
&lt;!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Transitional//EN&quot; &quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&quot;&gt; &lt;html...

6
интересующийся
311 / 282 / 93
Регистрация: 25.09.2010
Сообщений: 1,056
21.02.2013, 19:50
Цитата Сообщение от Maratovich Посмотреть сообщение
Доброго времени суток !
Помогите пожалуйста у меня значения не вставляются в начало списка.
Нужно просто запомнить начало. А у вас только "запаминается" во время возвращения функции конец, лучше всего (имхо) для этой цели исользовать глобальный указатель или не явно передавать его в функции add_last.

Добавлено через 2 минуты
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
#include <iostream>
using namespace std;
 
struct Node
{
    char data;
    Node *next;
};
 
Node global_first = NULL;
 
 
Node *add_last(Node *last,char data)
{   
    if(last == NULL)
    {
        last = new Node;
        global_first = last; // теперь есть указатель на первый элемент
    }
    else
    {
        last->next = new Node;
        last = last->next;
    }
    last->data = data;
    last->next = NULL;
    return last;
}
0
13 / 17 / 6
Регистрация: 05.09.2012
Сообщений: 210
21.02.2013, 20: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
#include <iostream>
using namespace std;
 
struct Node
{
    char data;
    Node *next;
};
 
 
Node *global_first = NULL;
 
Node *add_last(Node *last,char data)
{   
    if(last == NULL)
    {
        last = new Node;
        global_first = last;
    }
    else
    {
        last->next = new Node;
        last = last->next;
    }
    last->data = data;
    last->next = NULL;
    return last;
}
 
Node *add_first(Node *&global_first,char data)
{
    Node *first_insert = new Node;
    first_insert->data = data;
    first_insert->next = global_first;
    first_insert = first_insert->next;
    return first_insert;
}
 
void show(Node *global_first)
{   
    while(global_first != NULL)
    {
        cout <<global_first->data<<endl;
        global_first = global_first->next;
    }
}
 
int main(int argc, char const *argv[])
{
    Node *last;
    last = NULL;
 
    if(global_first == NULL)
    {
        global_first = add_last(last,'c');
        last = global_first;
    }
    else
    {
        last = add_last(last,'c');
    }
 
    global_first = add_first(global_first,'b');
    show(global_first);
 
    return 0;
}
0
интересующийся
311 / 282 / 93
Регистрация: 25.09.2010
Сообщений: 1,056
21.02.2013, 20:40
Изменил имя global_fisrt на first и подправил несколько ошибок:
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;
 
struct Node
{
    char data;
    Node *next;
};
 
Node *last = NULL;
Node *first = NULL;
 
Node *add_last(Node *last, char data)
{   
    if (last == NULL)
    {
        last = new Node;
        first = last;
    }
    else
    {
        last->next = new Node;
        last = last->next;
    }
    last->data = data;
    last->next = NULL;
    return last;
}
 
Node *add_first(Node *first,char data)
{
    Node *first_insert = new Node;
 
    first_insert->data = data;
    first_insert->next = first;
    first = first_insert;
    return first_insert;
}
 
void show(Node *first)
{   
    while(first != NULL) 
    {
        cout << first->data << endl;
        first = first->next;
    }
}
 
int main()
{
     
    if(first == NULL) // Эта проверка незачем, так как она осуществляется в функции add_last()
    {
        first = add_last(last,'c');
        last = first;
    }
    else
    {
        last = add_last(last,'c');
    }
 
    first = add_first(first,'b');
    show(first);
 
    return 0;
}
Добавлено через 3 минуты
Главная ошибка была, когда вы добавляли в начало то нужно было глобальному указателю first присваивать новое значение
1
13 / 17 / 6
Регистрация: 05.09.2012
Сообщений: 210
21.02.2013, 21:32  [ТС]
xtorne21st спасибо !

Добавлено через 43 минуты
Допустим я не хочу использовать всякие return'ы а просто передавать в качестве параметра адрес first last, возможно ли это ?
0
интересующийся
311 / 282 / 93
Регистрация: 25.09.2010
Сообщений: 1,056
21.02.2013, 22:42
легко). Вот пример с меню:
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
93
94
95
96
97
// Simple one_linked_list.
// "Простой" одноcвязный список.
 
#include <iostream>
#include <cstdlib>
 
// Для "отчистки std::cin".
#define CIN_HACK if (std::cin.peek() == '\n') std::cin.ignore()
 
struct Node
{
    std::string data; // Хранение данных (строка).
    Node* next; // Указатель на следующее звено.
};
 
Node *start = NULL;    // Это будет указатель на начало списка.
 
// Функция добавления узла.
void push()
{
    Node* info = NULL;
 
    // Если нет ни одного узла...
    if (!start) {
        info = new Node; // Выделяем память для первого узла.
        start = info; // Запаминаем начало.
        std::cout << "\nAdding new data: ";
        std::getline(std::cin, info->data); // Инициализируем данными.
        std::cout << '\n';
        info->next = NULL; // следующий элемент = NULL (признак линейного списка).
        return;
    }
 
    info = start; // Устанавливаем на начало.
    while (info->next) // Найдём конец.
        info = info->next;
    info->next = new Node; // Выделим память под новый узел.
 
    std::cout << "\nAdding new data: ";
    std::getline(std::cin, info->next->data); // Инициализируем данными.
    std::cout << '\n';
    info->next->next = NULL; // Следующий элемент = NULL (признак линейного списка).
}
 
// Функция отображает весь список.
void show()
{
    Node* info = start;
    
    std::cout << '\n';
    for (int i = 1; info; ++i) {
        std::cout << i << ") " << info->data << "\n";
        info = info->next;
    }
    std::cout << '\n';
}
 
// Функция освобождает память (уничтожает список).
void free_mem()
{
    Node* temp, *info;
 
    info = start;
    while (info) {
        temp = info; // Сохраняем указатель на текущий узел.
        info = info->next; // Перемещаемся на следующий объект.
        delete temp; // Удаляем текущий.
    } 
}
 
int main()
{
    for (char answer[10]; ; ) {
        std::cout << "1. Add node.\n";
        std::cout << "2. Show list.\n";
        std::cout << "3. Exit.\n : ";
        std::cin >> answer;
        CIN_HACK; // Игнорирует символ конца строки.
        switch (atoi(answer)) {
            case 1:
                push();
                break;
            case 2:
                show();
                break;
            case 3:
                free_mem(); // Освободить память перед выходом из программы.
                exit(0);
                break;
            default:
                std::cout << "\nWrong answer, try again.\n";
                break;
        }
    }
 
    return 0;
}
1
13 / 17 / 6
Регистрация: 05.09.2012
Сообщений: 210
23.02.2013, 13:52  [ТС]
Спасибо за помощь )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
23.02.2013, 13:52
Помогаю со студенческими работами здесь

Вставляются все найденные значения в одну ячейку, исправить код
Sub teeest() ' ' ' Dim oCell Dim sAddress As String Workbooks.Open...

Переставить элементы списка, удовлетворяющие некоторому предикату P, в начало списка
Можете помочь с заданием . Определите функцию (f s), которая в одноуровневом списке чисел s переставляет элементы, удовлетворяющие...

Двунаправленный список. Отрицательные элементы списка перенести в начало списка
Помогите написать программу. Дан двунаправленный список L, элементы которого являются целыми числами. Отрицательные элементы списка...

Найти минимальный элемент списка и переставить все его вхождения в начало списка
Допустим есть список , чтоб на выходе получилось

Получить указатель на элемент двунаправленного списка, добавить значение в начало списка и очистить его
Нужно создать двунаправленный список //вроде так, но не уверен struct Double_List {//структура данных int Data;...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
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