Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
Maratovich
13 / 17 / 1
Регистрация: 05.09.2012
Сообщений: 210
21.02.2013, 19:42     Значения не вставляются в начало списка #1
Доброго времени суток !
Помогите пожалуйста у меня значения не вставляются в начало списка.
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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
xtorne21st
интересующийся
300 / 271 / 19
Регистрация: 25.09.2010
Сообщений: 1,056
21.02.2013, 19:50     Значения не вставляются в начало списка #2
Цитата Сообщение от 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;
}
Maratovich
13 / 17 / 1
Регистрация: 05.09.2012
Сообщений: 210
21.02.2013, 20:10  [ТС]     Значения не вставляются в начало списка #3
Почему то все ровно не вставляется (

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;
}
xtorne21st
интересующийся
300 / 271 / 19
Регистрация: 25.09.2010
Сообщений: 1,056
21.02.2013, 20:40     Значения не вставляются в начало списка #4
Изменил имя 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 присваивать новое значение
Maratovich
13 / 17 / 1
Регистрация: 05.09.2012
Сообщений: 210
21.02.2013, 21:32  [ТС]     Значения не вставляются в начало списка #5
xtorne21st спасибо !

Добавлено через 43 минуты
Допустим я не хочу использовать всякие return'ы а просто передавать в качестве параметра адрес first last, возможно ли это ?
xtorne21st
интересующийся
300 / 271 / 19
Регистрация: 25.09.2010
Сообщений: 1,056
21.02.2013, 22:42     Значения не вставляются в начало списка #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
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;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.02.2013, 13:52     Значения не вставляются в начало списка
Еще ссылки по теме:

"Сортировка двусвязного списка путем исключения элемента с минимальным значением и включения его в начало нового списка C++
Разработать класс Итератор, методы которого: переход в начало списка, в конец, к текущему элементу списка, к с C++
Передача указателя на начало списка C++

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

Или воспользуйтесь поиском по форуму:
Maratovich
13 / 17 / 1
Регистрация: 05.09.2012
Сообщений: 210
23.02.2013, 13:52  [ТС]     Значения не вставляются в начало списка #7
Спасибо за помощь )
Yandex
Объявления
23.02.2013, 13:52     Значения не вставляются в начало списка
Ответ Создать тему
Опции темы

Текущее время: 21:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru