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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
bohdan_si
12 / 12 / 2
Регистрация: 03.10.2012
Сообщений: 83
#1

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

14.02.2013, 22:56. Просмотров 304. Ответов 2
Метки нет (Все метки)

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++
Список. есть пример программы: Создать динамический список. Удалить из него первый и последний элемент. #include <iostream.h> ...

Добавить в список элемент после элемента с заданным инф.полем [Однонаправленный список] - C++
Вообщем есть: Функция создание списка Функции вывода на экран Функция добавление элемента с номером k А нужно ввести...

Организовать ввод в однонаправленный список, узел списка состоит из двух полей: целое число и указатель - C++
Здравствуйте, нужна ваша помощь!!! Нужно написать программу Организовать ввод в однонаправленный список. Узел списка состоит из двух...

Организовать ввод в однонаправленный список. Узел списка состоит из двух полей: целое число и указатель. Не - C++
Организовать ввод в однонаправленный список. Узел списка состоит из двух полей: целое число и указатель. Необходимо добавить узел после...

Однонаправленный список. Операции: удалить элемент из заданной позиции, добавить элемент в заданную позицию,проверка на неравенство - C++
Помогите. Есть одна написанная. Условия: Очередь. Операции: “+” добавить элемент ; “-“ удалить элемент ; bool() проверка «Пуста...

Вернуть указатель на первый элемент - C++
Здравствуйте, помогите пожалуйста с проблемой:) Как вернуть указатель на первый элемент отсортированного списка, чтобы список...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
xtorne21st
интересующийся
304 / 275 / 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
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,924
Записей в блоге: 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;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.02.2013, 00:20
Привет! Вот еще темы с ответами:

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

Добавить в однонаправленный (двунаправленный) список элемент с заданным номером - C++
Добавить в однонаправленный (двунаправленный) список элемент с заданным номером

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

Создать однонаправленный список, перегрузить операции + [] == >> << - C++
Создать однонаправленный список с элементами типа char и перегрузить операции , &lt;&lt;, &gt;&gt;, ==, + Дублирование тем запрещено правилами...


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

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru