Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
13 / 2 / 2
Регистрация: 17.10.2012
Сообщений: 57

Двусвязный список (профан)

28.02.2015, 22:56. Показов 1289. Ответов 21
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем снова добрый вечер! Итак суть такова: есть двусвязный список непонятной информации(но это строки точно), смысл в том,что его создают до тех пор,пока не введена пустая строка. Обязательно надо использовать в программе указатель this (не спрашивайте зачем, такое задание). Я вроде как написала,но компилятор говорит мне фигу,а не написала.
Вот что он выдает :
prog.cpp:17: error: expected initializer before '*' token
prog.cpp: In function 'int main()':
prog.cpp:49: error: request for member 'Add_inform' in 'pv', which is of non-class type 'NODE*'
prog.cpp:50: error: request for member 'Add_NODE' in 'pv', which is of non-class type 'NODE*'
prog.cpp:52: error: request for member 'Display_All' in 'pv', which is of non-class type 'NODE*'
Буду благодарна,кто исправит ошибку/и и объяснит почему так.И даст хороший совет^^ Была бы премного благодарна.
Вот мой код:
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
#include <iostream>
#include <cstring>
 
using namespace std;
 
class NODE{ 
 
    static NODE*head;
    NODE *next;
    NODE *prev;
    char info[10];
    public:
    void Add_inform(char *s);
    void Add_NODE();
    void Display_All();
}
NODE* NODE::head=NULL;
 
void NODE::Add_NODE(){
    if(head == NULL){
    head=this;
    next=NULL;
    prev=NULL;
    }else{
        next=head;
        head=this;
        next->prev=this;
        prev=NULL;
    }
}
 
void NODE::Add_inform(char *s){
    strcpy(info,s);
    next->prev=NULL;
}
 
void NODE::Display_All(){
    NODE *p=head;
    while(p!=this){
    cout<<p->info<<'\n';
    }
}
 
int main(){
    char buf[50];
    NODE *pv;
    while(*gets(buf)!='\0'){
        pv=new NODE;
        pv.Add_inform(buf); 
        pv.Add_NODE();
    }
    pv.Display_All();
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.02.2015, 22:56
Ответы с готовыми решениями:

Переделать двусвязный список в двусвязный кольцевой
Здравствуйте, у меня єсть двусвязный список однако он не кольцевой! как это запрограммировать? и второй вопрос как обеспечить вставку...

Сформировать список из 10 работников, используя динамическую структуру данных двусвязный список
спасайте Сформировать список из 10 работников, используя динамическую структуру данных двусвязный список. Информация о работнике...

Двусвязный список (в конец двусвязного списка добавить другой список)
здравствуйте, подскажите пожалуйста, как в конец двусвязного списка добавить другой список?

21
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
01.03.2015, 20:21
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от Lokomoss Посмотреть сообщение
интересует что внутри, там класс в классе?
это конструктор, у структур тоже такая штука есть.

Конструктор используется как шлагбаум без которого в приват поле класса извне класса не попасть.
В конструктор отдается переменная, он ее принимает и уже внутри класса передает ее дальше.

C++
1
pv = new NODE(buf); //Отдали buf конструктору, а дальше уже она внутри класса обрабатывается.
C++
1
2
3
4
public:
    NODE(std::string const & x)
        : next(0), prev(0), info(x)  //x- это buf, x уходит в info класса NODE
    { }
1
13 / 2 / 2
Регистрация: 17.10.2012
Сообщений: 57
01.03.2015, 20:27  [ТС]
спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.03.2015, 20:27

Составить двусвязный список на основе класса, объекты которого будут формировать этот список
Составить двусвязный список на основе класса, объекты которого будут формировать этот список. В описание класса должны входить данные для...

Заменить массив структур на односвязный список, и на двусвязный список
Взять текст задания и заменить массив структур на односвязный список, и на двусвязный список using namespace std; class person { ...

Создать двусвязный список групп факультета, где каждая группа представляет собой односвязный список студентов
Задание: создайте двусвязный список групп факультета. Каждая группа представляет собой односвязный список студентов. Помогите пожалуйста,...

Преобразовать односвязный список в двусвязный список
Доброго времени суток! Помогите, пожалуйста, преобразовать программу из односвязного списка в двусвязный. Спасибо. #include...

Двусвязный список
Вот решил написать двусвязный список. Написаны только две функции решил попробовать работает или нет, оказалось, что нет. Компилятор...


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

Или воспользуйтесь поиском по форуму:
22
Ответ Создать тему
Новые блоги и статьи
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи. Через несколько переработок от PHP кода к C89 (надеюсь, 89). Но довольно запутанно получилось. Код для Linux. Но если убрать time и то, что с ним. . .
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы Всем привет! Хочу поделиться свежим (и довольно. . .
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения: - добавлена многоязычность - добавлено снятие скриншотов - добавлено поддержание бафов хождения по воде (для жреца, дк и шамана) - и так, по. . .
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru