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

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

Войти
Регистрация
Восстановить пароль
 
MsWatermelon
0 / 0 / 0
Регистрация: 05.03.2010
Сообщений: 7
#1

Структура,которая представляет односвязные списки - C++

09.07.2011, 23:18. Просмотров 333. Ответов 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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#include <stdio.h>
 
struct Item
{
       int x,y;
       Item *next;
       Item()
       {
           x=0;
           y=0;
       }
}
class List()
{
      Item *head;
      public:
             List();
             ~List();
             void push(Item *ptr);
             Item *pop();
             void show_all();
}
List::List()
{
   head=NULL;
}
List::~List()
{
   Item *ptr=head;
   while(ptr!=NULL)
   {
      Item *tmp=ptr->next;
      delete ptr;
      ptr=tmp;
   }
}
List::push(Item *ptr)
{
   ptr->next=head;
   head=ptr;
}
List::show_all()
{
   Item *ptr=head;
   while (ptr!=NULL)
   {
      Item *tmp=ptr->next;
      printf("%d,%d",(*ptr).x,(*ptr).y);
      ptr=tmp;
      ptr=ptr->next;
   }
}  
Item* List::pop()
{
      Item *tmp=head;
      if (head!=NULL)
      { head=head->next;
      return tmp;
      }
}
int main()
{
    list l1;
    l1.push(new Item);
    l1.push(new Item);
    Item *ptr=l1.pop();
    l1.show_all();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.07.2011, 23:18     Структура,которая представляет односвязные списки
Посмотрите здесь:

Односвязные линейные списки - C++
Подскажите пожалуйста, как заменить содержимое файла перечнем символов, которые в нем встречаются, упорядоченным в порядке убывания...

Односвязные списки, стек - C++
Помогите пожалуйста, кто может:(. нужно только дописать удаление. вот само задание: удаление из линейного стека входной...

Односвязные списки (очередь) - C++
Задание.Удалить с очереди все элементы, расположенные до минимального элемента очереди. Пример создания контейнера &quot;очередь&quot; с...

Односвязные линейные списки - C++
Здравствуйте! Помогите пожалуйста. Даны текстовый файл и строка s. Группы символов, разделенные пробелами, будем называть ...

Односвязные лнейные списки - C++
Доброго времени суток. Нужно решить задачу, а я в списках не шарю совсем(и скока не пытался разобраться-не получиилось) Вот задача ...

Односвязные списки: как работают? - C++
Здрасте всем! Есть такой вот односвязный список, объясните пожалуйста, как будет выглядеть функция добавления записи в конец такого...

Односвязные списки - элемент перезаписывается - C++
Помогите пожалуйста функция добавления элемента: void AddSpisok(SpisokSport **begin) { SpisokSport *end; if(*begin==NULL) { ...

Односвязные списки: реализация стека - C++
Я никак не могу реализировать полноценный стек не используя масив, у меня есть #include &lt;iostream&gt; using namespace std; struct...

Односвязные списки (найти литературу) - C++
нужно найти литературу по этому вопросу. есть ли у кого &quot;очень понятная&quot; литература по этому вопросу?

Односвязные списки (функции обращения списка) - C++
1. Написать рекурсивную функцию обращения списка. 2. Написать итеративную функцию обращения списка. :С попытался написать, так и не...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
silent_1991
Эксперт С++
4960 / 3036 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
09.07.2011, 23:28     Структура,которая представляет односвязные списки #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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#include <stdio.h>
 
struct Item
{
       int x,y;
       Item *next;
       Item()
       {
                   x=0;
           y=0;
           }
};
class List
{
      Item *head;
      public:
             List();
             ~List();
             void push(Item *ptr);
             Item *pop();
             void show_all();
};
List::List()
{
   head=NULL;
}
List::~List()
{
   Item *ptr=head;
   while(ptr!=NULL)
   {
      Item *tmp=ptr->next;
      delete ptr;
      ptr=tmp;
   }
}
void List::push(Item *ptr)
{
   ptr->next=head;
   head=ptr;
}
void List::show_all()
{
   Item *ptr=head;
   while (ptr!=NULL)
   {
      Item *tmp=ptr->next;
      printf("%d,%d",(*ptr).x,(*ptr).y);
      ptr=tmp;
      ptr=ptr->next;
   }
}  
Item* List::pop()
{
      Item *tmp=head;
      if (head!=NULL)
      { head=head->next;
      return tmp;
      }
}
int main()
{
    List l1;
    l1.push(new Item);
    l1.push(new Item);
    Item *ptr=l1.pop();
    l1.show_all();
}
Однако сам список настолько криво реализован, что лучше переписать его с нуля, почитав перед этим хотя бы несколько первых глав из любой книги по C++, а так же покурить ман по спискам.
MsWatermelon
0 / 0 / 0
Регистрация: 05.03.2010
Сообщений: 7
09.07.2011, 23:34  [ТС]     Структура,которая представляет односвязные списки #3
Спасибо,мне нет оправдания,но вот так нас за две недели хотят научить прогать на C++.
Ответ Создать тему
Опции темы

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