22.04.2010, 15:16. Просмотров 381. Ответов 7
Добрый день! Мне необходимо разбить 1 класс на 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
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
| #include<iostream.h>
#include<stddef.h>
#include<conio.h>
struct Node
{
int key;
Node *link;
};
class List
{
public:
List (int nn) { n=nn; MakeList(n) ;};
~List() { cleanList (head) ;};
void Out() { printList(head) ;};
protected:
void MakeList(int n);
void printList(Node *p);
void cleanList(Node *p);
Node *head, *p;
int n,k;
};
class List1:public List
{
public:
List1(int nn):List(nn);
~List1 ();
void Work(int kk) { k=kk; p=searchPair(head); Paste(k) ;};
private:
Node *searchPair(Node *p);
void Paste (int k);
};
void List::MakeList(int n)
{
int key;
cin>>key; head=new Node; head->key=key; p=head; n--;
while(n) {
cin>>key; p->link=new Node; p=p->link; p->key=key; n--;
}
p->link=NULL;
}
Node *List1::searchPair(Node *p)
{
if (!p->link->link->link) return NULL;
else {
if ((p->link->key+p->link->link->key)>p->link->link->link->key) return p;
else return searchPair(p->link);
}
}
void List1::Paste (int k)
{ Node *i;
i=new Node;
i->link=p->link;
i->key=k;
p->link=i;
}
void List::printList(Node *p)
{
if (p) {
cout<<p->key<<" ";
printList(p->link);
}
}
void List::cleanList(Node *p)
{
if (p) {
cleanList(p->link);
delete p;
}
}
void main()
{
clrscr();
int k,n;
cout <<"\nKol-vo elementov spiska: ";
cin >>n;
cout <<"\nNew Element: ";
cin >>k;
cout<<"\nVvedite " <<n<<" Elementov spiska\n";
List rt(n);
List1 rt1(n);
rt1.Work(k);
cout<<"\n\nРезультат: ";
rt.Out();
getch();
} |
|
Исходный(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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
| #include<iostream.h>
#include<stddef.h>
#include<conio.h>
struct Node
{
int key;
Node *link;
};
class List
{
public:
List (int nn) { n=nn; MakeList(n) ;};
~List() { cleanList (head) ;};
void Out() { printList(head) ;};
void Work(int kk) { k=kk; p=searchPair(head); Paste(k) ;};
private:
void MakeList(int n);
void Paste (int k);
Node *searchPair(Node *p);
void printList(Node *p);
void cleanList(Node *p);
Node *head, *p;
int n,k;
};
void List::MakeList(int n)
{
int key;
cin>>key; head=new Node; head->key=key; p=head; n--;
while(n) {
cin>>key; p->link=new Node; p=p->link; p->key=key; n--;
}
p->link=NULL;
}
Node *List::searchPair(Node *p)
{
if (!p->link->link->link) return NULL;
else {
if ((p->link->key+p->link->link->key)>p->link->link->link->key) return p;
else return searchPair(p->link);
}
}
void List::Paste (int k)
{ Node *i;
i=new Node;
i->link=p->link;
i->key=k;
p->link=i;
}
void List::printList(Node *p)
{
if (p) {
cout<<p->key<<" ";
printList(p->link);
}
}
void List::cleanList(Node *p)
{
if (p) {
cleanList(p->link);
delete p;
}
}
void main()
{
clrscr();
int k,n;
cout <<"\nKol-vo elementov spiska: ";
cin >>n;
cout <<"\nNew Element: ";
cin >>k;
cout<<"\nVvedite " <<n<<" Elementov spiska\n";
List rt(n);
rt.Work(k);
rt.Out();
rt.~List();
getch();
} |
|