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

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

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

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

09.07.2011, 23:18. Просмотров 336. Ответов 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++
Есть программа которая должна выводить координаты точки (x.y.z) Ввод должен выполняться путем считывания из файла, Сделал все кроме...

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

Односвязные списки - C++
Задача: добавить в список 1 узлы, содержащие слова в списке 2, не совпадающие со словами списка 1(линейный список 1 из слов хранится в...

Односвязные списки - C++
Вечер добрый) Сформировать список символов, оканчивающийся точкой. Заменить в списке символ “A” на символ “0”. Сама задача есть и...

Односвязные списки С++ - C++
Помогите пожалуйста с заданием: Необходимо создать список(из целых чисел) добавлением элемента в конец... Я написала программу,только...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
silent_1991
Эксперт С++
4963 / 3039 / 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++.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.07.2011, 23:34
Привет! Вот еще темы с ответами:

односвязные списки С++ - C++
Дана последовательность символов s1 , s2 , . . . , sn ( n &gt;= 2 и заранее неизвестно). Получить те символы, принадлежащие...

Односвязные списки - C++
помогите написать функцию которая меняет местами два элемента списка, заданные значением информационной части. Node *peremena(Node...

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

Односвязные списки - C++
Всем доброго времени суток. Мне нужно реализовать вот эти операторы в односвязном списке: void gotoTail() void addToTail(Node* node) ...


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

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

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