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

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

Восстановить пароль Регистрация
 
MsWatermelon
0 / 0 / 0
Регистрация: 05.03.2010
Сообщений: 7
09.07.2011, 23:18     Структура,которая представляет односвязные списки #1
Помогите пожалуйста если не трудно.Во-первых ,почему то программа не хочет компилироваться.Во-вторых каким образом для данного класса объекты могут выделяться динамически.

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++ Односвязные списки
Односвязные списки C++
Односвязные списки C++
C++ Односвязные списки С++
C++ Односвязные линейные списки
Односвязные списки C++
C++ Односвязные списки (очередь)
односвязные списки С++ C++
Односвязные линейные списки C++
Односвязные списки C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
silent_1991
Эксперт C++
4945 / 3021 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 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++.
Yandex
Объявления
09.07.2011, 23:34     Структура,которая представляет односвязные списки
Ответ Создать тему
Опции темы

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