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

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

Войти
Регистрация
Восстановить пароль
 
Писарев Иван
0 / 0 / 0
Регистрация: 05.09.2012
Сообщений: 44
#1

Неполный тип - C++

09.11.2012, 20:50. Просмотров 924. Ответов 3
Метки нет (Все метки)

Доброго времени суток. Написал следующую программу:

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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
#include <iostream>
#include <iomanip>
#include <string>
#include <string.h>
#include <conio.h>
 
 
using namespace std;
 
enum K(vilez);
 
//-----------------------------------------------------------------------------------------//
 
 
class int_class
{
    struct basic;
    basic* first;
    basic* last;
    basic* return_index(int a);
public:
    ~int_class();
    int_class()
    {
        first=NULL;
        last=NULL;
    }
    int_class(int_class &A)
    {
        first=NULL;
        last=NULL;
        this->copy(A);
    }
    void add_end(int a);
    void delete_end();
    void add_index(int a, int index);
    void del_index(int index);
    void copy(int_class C);
    int return_int(int index);
    int kol();
    basic* operator[](int a)
    {
        return(return_index(a));
    }
    int_class* operator=(int_class &A)
    {
        this->copy(A);
        return(this);
    }
};
 
int_class::~int_class()
{
        if(this->first)
        {
            basic* bred=first;
            do
            {
                basic* del=bred;
                bred=bred->next;
                delete del;
            }while(first);
            first=NULL;
            last=NULL;
        }
}
 
struct int_class::basic
{
public:
    basic* next;
    basic* before;
    int value;
    basic()
    {
        next=NULL;
        before=NULL;
        value=0;
    }
    basic(int a)
    {
        next=NULL;
        before=NULL;
        value=a;
    }
};
 
void int_class::add_end(int a)
{
    if(!first) first=new basic, first->value=a, last=first;
    else
    {
        basic* new_elment=new basic;
        new_elment->value=a;
        basic* intermediate=first;
        while(intermediate->next) intermediate=intermediate->next;
        intermediate->next=new_elment;
        new_elment->before=intermediate;
        last=new_elment;
    }
}
 
void int_class::delete_end()
{
    basic* delete_element=last;
    last=last->before;
    if(last->next) last->next=NULL;
    delete delete_element;
}
 
int_class::basic* int_class::return_index(int a)
{
    basic* intermediate=first;
    for(int i=0; i<a; i++) 
    {
        if(!intermediate) throw(vilez);
        intermediate=intermediate->next;
    }
    return(intermediate);
}
 
void int_class::add_index(int a, int index)
{
    basic* new_element=new basic;
    new_element->value=a;
    basic* intermediate=this->return_index(index);
    if(intermediate->before) intermediate->before->next=new_element, new_element->before=intermediate->before;
    intermediate->before=new_element;
    new_element->next=intermediate;
    if(index==0) first=new_element;
}
 
void int_class::del_index(int index)
{
    basic* intermediate=this->return_index(index);
    if(intermediate->before) intermediate->before->next=intermediate->next, intermediate->next->before=intermediate->before;
    else first=first->next;
    delete intermediate;
}
 
int int_class::return_int(int index)
{
    basic* intermediate=this->return_index(index);
    return(intermediate->value);
}
 
int int_class::kol()
{
    int schet=0;
    basic* intermediate=this->last;
    while(intermediate)
    {
        schet++;
        intermediate=intermediate->next;
    }
    return(schet);
}
 
void int_class::copy(int_class C)
{
    this->~int_class();
    for(int i=0; i<C.kol()+1; i++) this->add_end(C.return_int(i));
}
 
//--------------------------------------------------------------------------------------------------------//
 
void main()
{
    int_class A;
    setlocale(0, "");
    system("color f0");
    int question=1;
    try
    {
        while(question>0&&question<8)
        {
            cout<<endl<<"Выберите следующий пункт из меню: ";
            cout<<endl<<"1) Вставить элемент в конец списка ";
            cout<<endl<<"2) Удалить последний элемент в списке ";
            cout<<endl<<"3) Вставить элемент по задонном индексу ";
            cout<<endl<<"4) Удалить элемент по заданному индексу ";
            cout<<endl<<"5) Получить занчение элемента по заданному индексу ";
            cout<<endl<<"6) Вывести на экран колличество элементов в списке ";
            cout<<endl<<"7) Exit ";
            cin>>question;
            switch(question)
            {
            case(1):
                {
                    int a;
                    cout<<"Введите целое число ";
                    cin>>a;
                    A.add_end(a);
                };break;
            case(2):
                {
                    A.delete_end();
                };break;
            case(3):
                {
                    int a;
                    cout<<"Введите число ";
                    cin>>a;
                    int index;
                    cout<<"Введите индекс элемента ";
                    cin>>index;
                    A.add_index(a, index-1);
                };break;
            case(4):
                {
                    int index;
                    cout<<"Введите индекс элемента ";
                    cin>>index;
                    A.del_index(index-1);
                };break;
            case(5):
                {
                    int index;
                    cout<<"Введите индекс элемента ";
                    cin>>index;
                    cout<<"Значение элемента с заданным индексом: "<<A.return_int(index-1);
                };break;
            case(6):
                {
                    cout<<"Количество элементов: "<<A.kol();
                };break;
            case(7):
                {
                    A.~int_class();
                };break;
            }
        }
    }
    catch(K &c)
    {
        if(c==vilez) cout<<"Извините, не существует элемента с данным индексом. Программа завершает работу. ", A.~int_class(), _getch();
    }
}
Возникли следующие ошибки:
Ошибка 2 error C2227: выражение слева от "->next" должно указывать на тип класса, структуры или объединения либо на универсальный тип c:\users\user\documents\visual studio 2010\projects\09\09\8.cpp 60 1 09
Ошибка 1 error C2027: использование неопределенного типа "int_class::basic" c:\users\user\documents\visual studio 2010\projects\09\09\8.cpp 60 1 09

Ошибка на данном участке кода:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int_class::~int_class()
{
        if(this->first)
        {
            basic* bred=first;
            do
            {
                basic* del=bred;
                bred=bred->next;
                delete del;
            }while(first);
            first=NULL;
            last=NULL;
        }
}
Что я сделала не так? Заранее спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.11.2012, 20:50     Неполный тип
Посмотрите здесь:

Неполный тип данных - C++
Компилятор выдает ошибку неполный тип данных, ругается на строку с объявлением процедуры void DrawGrid(HDC *hdc); и с самой процедурой ...

Недопустимый неполный тип - C++
Здравствуйте! Помогите решить проблему с недопустимы полным типом. Код: main.cpp #include &quot;headers.h&quot; #include &quot;support.h&quot; int...

Односвязные списки: недопустимый неполный тип - C++
По книге Седжвика пишу реализацию списков. Есть такие файлы: list.h: #ifndef LIST_H #define LIST_H struct data; struct...

union REGS rg; недопустимый неполный тип - C++
Прерывания с клавиатуры Может я чего не подключил ещё нужного? #include &quot;stdafx.h&quot; #include &lt;stdio.h&gt; #include &lt;dos.h&gt; ...

Недопустимый неполный тип, не могу найти ошибку - C++
#include&lt;iostream&gt; #include&lt;locale&gt; #include&lt;string&gt; #include&lt;iomanip&gt; #include&lt;fstream&gt; void Poisk_1(), Poisk_2(), Poisk_3(),...

выдаёт неполный ответ... - C++
#include &lt;iostream&gt; #include &lt;conio.h&gt; # define n 5 using namespace std; int main (void) { int mass,i,j,max,a; ...

Неполный хэш MD5 - C++
Добрый вечер. Сегодня пытался реализовать функцию хеширования по одному примеру. Но почему в итоге вычисления получается не совсем полный...

Обьясните пожайлуста как и что делает данный оператор в этом выражении fState [x][y] ^= 1;. Неполный код привожу ниже. - C++
Вот код программы из книжки Ч. Петзолд (Програмирование для Windows® 95) #define DIVISIONS 5 ... ... LRESULT CALLBACK WndProc(HWND...

8.Дан список населенных пунктов области с описанием: название, кол-во жителей, тип. Тип выбирается из списка: город, районный цент, село, поселок г - C++
8.Дан список населенных пунктов области с описанием: название, кол-во жителей, тип. Тип выбирается из списка: город, районный цент,...

Багаж пассажира характеризуется количеством вещей (целый тип) и общим весом вещей (вещественный тип). - C++
Помогите пожалуйста с задачей: вот условие: Багаж пассажира характеризуется количеством вещей (целый тип) и общим весом вещей...

Комбинированный тип. Тип запись - C++
Тип запись typedef.. Прошу помочь с основными операциями над структурами, желательно без указателей. Интересует поиск, выбор, вывод.. да...

Недопустимый неполный тип - C (СИ)
class ZNAK { private: int TIME; // Время рождения int BDAY; // День рождения char NAME; // Фамилия, имя ...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Kuzia domovenok
1889 / 1744 / 117
Регистрация: 25.03.2012
Сообщений: 5,922
Записей в блоге: 1
09.11.2012, 20:55     Неполный тип #2
в какой строке?
Писарев Иван
0 / 0 / 0
Регистрация: 05.09.2012
Сообщений: 44
09.11.2012, 20:58  [ТС]     Неполный тип #3
В этой:
C++
1
bred=bred->next;
Croessmah
Модератор
Эксперт CЭксперт С++
12979 / 7291 / 812
Регистрация: 27.09.2012
Сообщений: 18,007
Записей в блоге: 3
Завершенные тесты: 1
09.11.2012, 21:00     Неполный тип #4
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
struct int_class::basic
{
public:
    basic* next;
    basic* before;
    int value;
    basic()
    {
        next=NULL;
        before=NULL;
        value=0;
    }
    basic(int a)
    {
        next=NULL;
        before=NULL;
        value=a;
    }
};
 
int_class::~int_class()
{
        if(this->first)
        {
            basic* bred=first;
            do
            {
                basic* del=bred;
                bred=bred->next;
                delete del;
            }while(first);
            first=NULL;
            last=NULL;
        }
}
поменял местами эти фрагменты кода. Basic должен быть определен перед использованием
Yandex
Объявления
09.11.2012, 21:00     Неполный тип
Ответ Создать тему
Опции темы

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