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

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

Войти
Регистрация
Восстановить пароль
 
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
#1

Реализовать простейшие операции над списком: вставка, удаление, вывод на экран - C++

11.02.2013, 18:31. Просмотров 679. Ответов 7
Метки нет (Все метки)

Народ спасайте! Помогите реализовать простейшие операции над списком: вставка, удаление, вывод на экран. Я уже столько книг перечитал на эту тему, но все равно не могу понять.
Допустим у нас есть такая структура
C++
1
2
3
4
5
struct list
{
     int data;
     int* next;
};
Как к ней будут выглядеть операции?
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.02.2013, 18:31     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран
Посмотрите здесь:

Реализовать ввод, вывод и простейшие операции с матрицами C++
C++ Как реализовать работу со списком строк и списком цифр в классе List?
Простейшие действия над элементами матриц C++
C++ Swich: реализовать все возможные операции над двумя целыми числами
Двоичное дерево (операции вставка, удаление, поиск) C++
Строковые массивы, вывод и операции над числами в двумерном массиве C++
Связный список (создать и реализовать операции над ним) C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ev[G]eN
Эксперт С++
5095 / 1533 / 381
Регистрация: 23.01.2011
Сообщений: 3,148
11.02.2013, 18:51     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран #2
http://www.cplusplus.com/reference/list/list/
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
11.02.2013, 18:54  [ТС]     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран #3
Я знаю, что все уже придумано, но все же хочется понять как оно работает!
И наверное правильно вот так будет)
C++
1
2
3
4
5
struct list
{
     int data;
     list* next;
};
Kastaneda
Форумчанин
Эксперт С++
4259 / 2791 / 219
Регистрация: 12.12.2009
Сообщений: 7,119
Записей в блоге: 1
Завершенные тесты: 1
11.02.2013, 19:46     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран #4
Класс "list" со всеми необходимыми методами приведен и объяснен в каждой второй книге по С++.
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
11.02.2013, 22:53  [ТС]     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран #5
Здесь кое что нашел, и меня интересует вот это: first = p; это присвоений для того чтобы последний элемент который мы вставили был первым?
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
#include <iostream.h>
 
struct Item {
int info;
Item* next;
};
 
int main ( )
{
    Item *first = 0; //Указатель на начало списка
    Item *p;
    int i;
// Создать список
    for (;;) {
        // Вводить числа, пока не введем 0
        cin >> i;
        if (!i) break;
 
        // Создать новый элемент списка
        p = new Item;
        p->info = i;
 
        // Присоединить новый элемент к началу списка
        p->next = first ;
        
        first = p;
     }
 
// Пройти список и вывести элементы
p = first;
while (p) {
     cout << p->info <<" " ;
     p = p->next;
}
 
// Пройти список и удалить элементы
while (first) {
      p = first;
      first = first->next ;
      delete p;
}
system("pause");
}
Jupiter
Каратель
Эксперт C++
6549 / 3969 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
11.02.2013, 23:10     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран #6
Цитата Сообщение от The_bolT Посмотреть сообщение
first = p; это присвоений для того чтобы последний элемент который мы вставили был первым?
да.
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
11.02.2013, 23:14  [ТС]     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран #7
А как переделать чтобы элементы добавлялись до конца, а не до начала?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.02.2013, 23:43     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран
Еще ссылки по теме:

Операции над однонаправленным списком C++
Реализовать базовые операции над множествами: объединение, пересечение, дополнение C++
Реализовать классические операции над множествами - объединение, пересечение и симметричная разность C++
C++ Реализовать 4 функции на простейшие арифметические операции (+,-, *, /)
Реализовать операции над множествами C++

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

Или воспользуйтесь поиском по форуму:
Jupiter
Каратель
Эксперт C++
6549 / 3969 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
11.02.2013, 23:43     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран #8
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от The_bolT Посмотреть сообщение
А как переделать чтобы элементы добавлялись до конца, а не до начала?
например так
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
    Item *first = 0; //Указатель на начало списка
    Item obj;
    Item *p = &obj;
    
    int i;
// Создать список
    for (;;) {
        // Вводить числа, пока не введем 0
        cin >> i;
        if (!i) break;
 
        // Создать новый элемент списка
        p->next = new Item;
        p = p->next;
        p->info = i;
   }
   first = obj.next;
Yandex
Объявления
11.02.2013, 23:43     Реализовать простейшие операции над списком: вставка, удаление, вывод на экран
Ответ Создать тему
Опции темы

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