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

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

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

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

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

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

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

Реализовать 4 функции на простейшие арифметические операции (+,-, *, /) - C++
Начал изучать указатели. Вошёл туго. Очень хочу разобраться самостоятельно, но задачи сдавать тоже нужно. Прошу помощи в решении задачи. ...

Операции над однонаправленным списком - C++
В лабораторній роботі необхідно організувати однонапрямлений список із структурою взятої із лабораторної роботи №1 згідно з варіантом та...

Реализовать операции над множествами - C++
Собственно только началась учеба на первом курсе,и вот препод задал написать програму,которая реализует все действия над...

Двоичное дерево (операции вставка, удаление, поиск) - C++
Вообщем пытаюсь научиться работать с двоичными деревьями. Информацию беру с википедии: ru.wikipedia.org. Пока пытаюсь реализовать...

Связный список (создать и реализовать операции над ним) - C++
Помогите, пожалуйста, доделать задание. Мне нужно создать связный список и реализовать операции над ним. 1. Создание списка из файла. ...

7
Ev[G]eN
iOS/Android Developer
Эксперт С++
5097 / 1535 / 381
Регистрация: 23.01.2011
Сообщений: 3,148
11.02.2013, 18:51 #2
http://www.cplusplus.com/reference/list/list/
0
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;
};
0
Kastaneda
Нарушитель
Эксперт С++
4676 / 2880 / 234
Регистрация: 12.12.2009
Сообщений: 7,314
Записей в блоге: 2
Завершенные тесты: 1
11.02.2013, 19:46 #4
Класс "list" со всеми необходимыми методами приведен и объяснен в каждой второй книге по С++.
0
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");
}
0
Jupiter
Каратель
Эксперт С++
6559 / 3980 / 227
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
11.02.2013, 23:10 #6
Цитата Сообщение от The_bolT Посмотреть сообщение
first = p; это присвоений для того чтобы последний элемент который мы вставили был первым?
да.
0
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
11.02.2013, 23:14  [ТС] #7
А как переделать чтобы элементы добавлялись до конца, а не до начала?
0
Jupiter
Каратель
Эксперт С++
6559 / 3980 / 227
Регистрация: 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;
1
11.02.2013, 23:43
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.02.2013, 23:43
Привет! Вот еще темы с ответами:

Реализовать базовые операции над множествами: объединение, пересечение, дополнение - C++
Вот как звучит задание: &quot;Объект: множество символов алфавита. Реализовать базовые операции над множествами: объединение, пересечение,...

Swich: реализовать все возможные операции над двумя целыми числами - C++
Составить программу, которая бы реализовала все возможные операции над двумя целыми числами (умножение, сложение, вычитание, деление,...

Реализовать классические операции над множествами - объединение, пересечение и симметричная разность - C++
Создать параметризованный тип данных - множество. Этот тип предназначен для хранения множества элементов и выполнения операций над ними....

Строковые массивы, вывод и операции над числами в двумерном массиве - C++
Как задать динамически массив строк (строк должно быть 10, может и статический подойдет?) и как оперировать над числами в двумерном...


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

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

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