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

Заполнение односвязного списка - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 33, средняя оценка - 4.94
//Александр
 Аватар для //Александр
6 / 6 / 0
Регистрация: 15.04.2010
Сообщений: 151
23.09.2010, 22:14     Заполнение односвязного списка #1
как ввести данные в список?
C++
1
2
3
4
5
struct LIST
{
       int data;
       LIST*next;
};
пишу на С++
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.09.2010, 22:14     Заполнение односвязного списка
Посмотрите здесь:

копирование односвязного списка C++
[C++]сортировка односвязного списка C++
C++ Сортировка односвязного списка
C++ шаблон односвязного списка
C++ сортировка односвязного списка
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
gooseim
Эксперт C++
500 / 404 / 35
Регистрация: 23.09.2010
Сообщений: 1,139
23.09.2010, 22:25     Заполнение односвязного списка #2
LIST list={100, NULL};
пишу на С++
Зачем тогда изобретать велосипед? Есть std::list.
Genius Ignat
1233 / 771 / 44
Регистрация: 16.09.2009
Сообщений: 2,014
23.09.2010, 22:26     Заполнение односвязного списка #3
Большая коллекция решенных задач

Смотри структуры данных, может что полезного найдешь.
//Александр
 Аватар для //Александр
6 / 6 / 0
Регистрация: 15.04.2010
Сообщений: 151
23.09.2010, 22:34  [ТС]     Заполнение односвязного списка #4
а можете привести пример где список создается заполняется данными с клавиатуры и выводится на дисплей??
Genius Ignat
1233 / 771 / 44
Регистрация: 16.09.2009
Сообщений: 2,014
23.09.2010, 22:55     Заполнение односвязного списка #5
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
#include <iostream.h>
 
//Структура - элемент стека
struct Node {
        int d;         //данные элемента структуры
        Node *p;       //Указатель для связи между структурами такого же типа
};
//-----------------------------
Node *first(int d);            //Формирование первого элемента(new)
void push(Node **top,int d);   //Добавление в стек (new)
int pop(Node **top);           //Выборка из стека  (delete)
//-----------------------------
//Главная функция
int main(){
        Node *top=NULL;          //Начальная инициализация указателя-вершины нулевым адресом .       
      
int t(0);
cout<<"Input data: ";cin>>t;
top=first(t);                 //Создание первого элемента стека     
for(int i=2;i<6;i++){
cout<<"input data: ";cin>>t;
push(&top,t);        //Добавление в стек четырёх элементов   
}
cout<<'\n':
while(top)            //Цикл вывода на экран значений элементов стека,и удаление их из памяти.                  
{                        //Цикл длится пока на вершину(в указатель top) не попадёт нулевой адрес.
cout<<'\n';           //Переход на следующую строку в консоли.
cout<<pop(&top)<<' '; //Вывод значений возвращаемых функцией pop(...)              
}
cout<<'\n';           //Переход на следующую строку в консоли.
        return 0;       //Возвращаем,что всё норм.                  
}
//------------------------------
//Начальное формирование стека
Node *first(int d){
        Node *pv=new Node;   //Создаём элемент: структура.
        pv->d=d;             //Присваиваем полю данных значения.
        pv->p=0;             //Первый элемент даёт признак конца стека NULL нужно при выборке. 
      cout<<pv->d<<' ';    //Выводи значение поля структуры. Это тоже можно убрать.
        return pv;           //Возвращаем адрес структуры.
}
 
//Занесение в стек
void push(Node **top,int d){
Node *pv=new Node;         //Создаём элемент: структура.
pv->d=d;                   //Присваиваем полю данных значения.
pv->p=*top;                //Созданный Элемент. Связыва-ся с элементом,который сейчас на Вершине
*top=pv;                   //Созданный Элемент: помещ-тся на вершину стека вместо старой вершины
cout<<(*top)->d<<' ';      //Выводится значение Созданного элемента Этот момент можно убрать.
}
//-----------------------------
//Выборка из стека
int pop(Node **top){
int temp=(*top)->d;        //Получаем значение элемента из вершины.
Node *pv=*top;             //Получаем адрес елемента из вершины.
(*top)=(*top)->p;            //В вершину помещаем новый элемент.
delete pv;                 //Удаляем старую вершину.
return temp;               //Возвращаем значение элемента из старой вершины.
}
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9373 / 5423 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
23.09.2010, 23:23     Заполнение односвязного списка #6
Цитата Сообщение от //Александр Посмотреть сообщение
а можете привести пример где список создается заполняется данными с клавиатуры и выводится на дисплей??
ну а самому-то поискать - не? Re: Список.
Yandex
Объявления
23.09.2010, 23:23     Заполнение односвязного списка
Ответ Создать тему
Опции темы

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