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

Однонаправленный список, где создать указатель на первый элемент? - C++

Восстановить пароль Регистрация
 
bohdan_si
12 / 12 / 2
Регистрация: 03.10.2012
Сообщений: 83
14.02.2013, 22:56     Однонаправленный список, где создать указатель на первый элемент? #1
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
struct listNode{
    char data;
    listNode *next;
};
 
class List{
    public:
        void add(char);
        int delete (int);
        int search(int);
        //int isEmpty();
};
 
List::add(_____){
    
 
}
Подскажите пожалуйста, для того чтобы добавить даные в список каким типом в add нужно создать переменные?
Где создать указатель на первый елемент списка?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.02.2013, 22:56     Однонаправленный список, где создать указатель на первый элемент?
Посмотрите здесь:

Создать однонаправленный список, перегрузить операции + [] == >> << C++
Создать динамический список. Удалить из него первый и последний элемент. C++
Добавить в однонаправленный (двунаправленный) список элемент с заданным номером C++
C++ Создать класса «однонаправленный кольцевой список».
C++ Линейно-однонаправленный список (удалить элемент списка по ключу)
C++ однонаправленный список элементов (удвоить каждый элемент списка)
C++ Однонаправленный список. Операции: удалить элемент из заданной позиции, добавить элемент в заданную позицию,проверка на неравенство
C++ Создать однонаправленный кольцевой список целых чисел

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
xtorne21st
интересующийся
300 / 271 / 19
Регистрация: 25.09.2010
Сообщений: 1,056
15.02.2013, 00:09     Однонаправленный список, где создать указатель на первый элемент? #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
29
30
31
32
33
34
35
36
37
#include <iostream>
 
struct listNode{
    char data;
    listNode *next;
};
 
ListNode* start = NULL; // указатель на первый элемент (управляющим элементом)
 
class List{
    public:
        List() {}
        ~List() {}
        void add(char);
        int remove_list (int);
        int search(int);
        //int isEmpty();
};
 
void add(char c)
{
    listNode* info = start;
 
    if (!info) { // если нет ни одного элемента
        info = new listNode;
        start = info; // запомним начало
        info->next = NULL; // делаем указатель на следующим эл. равным нулю
        info->data = c;
        return;
    }
 
    while (info->next) // найдём конец
        info = info->next;
    info->next = new listNode;
    info->next->next = NULL;
    info->next->data = c;
}
Kuzia domovenok
 Аватар для Kuzia domovenok
1882 / 1737 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
15.02.2013, 00:20     Однонаправленный список, где создать указатель на первый элемент? #3
Цитата Сообщение от xtorne21st Посмотреть сообщение
ListNode* start = NULL; // указатель на первый элемент (управляющим элементом)
следовало сделать полем класса. Всё-таки списков может быть несколько разных, не говорю уж что просто даже если б был только один, класс следовало б держать в целости, не вынося данные в глобальные переменные.

Цитата Сообщение от xtorne21st Посмотреть сообщение
while (info->next) // найдём конец
* * * * info = info->next;
Если добавлять в конец не принципиально, в однонаправленных списках лучше делать добавление в начало. Ибо проще и короче.
C++
1
2
3
4
5
6
7
void add(char c)
{
    listNode* info = new listNode;
    info->next = start;
    info->data = c;
    start=info;
}
Yandex
Объявления
15.02.2013, 00:20     Однонаправленный список, где создать указатель на первый элемент?
Ответ Создать тему
Опции темы

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