-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.cpp
91 lines (86 loc) · 2.72 KB
/
main.cpp
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
#include "node.h"
#include "tree.h"
#include "Student.cpp"
int main(){
setlocale(LC_ALL, "ru");
Tree<int> intTree;
intTree << 8;
intTree << 3;
intTree << 10;
intTree << 1;
intTree << 6;
intTree << 4;
intTree << 7;
intTree << 14;
intTree << 13;
cout << "все листья дерева" << endl;
intTree.inorder_walk(intTree.get_root());
cout << endl << endl;
cout << "разделение дерева" << endl;
intTree.inorder_walk(intTree/6);
cout << "удаление элемента 7" << endl;
intTree >> intTree.find_node(intTree.get_root(), 7);
cout << endl;
cout << "дерево после удаления" << endl;
intTree.inorder_walk(intTree.get_root());
cout << endl;
cout << "Количество листьев в дереве" << endl;
cout << intTree.operator int();
cout << endl;
cout << "максимальный элемент на уровне 2" << endl;
cout << intTree(2)->get_data();
cout << endl;
cout << "поиск элемента с ключем 10" << endl;
cout << intTree[10]->get_data();
cout << endl;
cout << "исключение" << endl;
Tree<int> intTree1(intTree);
try {
intTree >> intTree.find_node(intTree.get_root(), 26);
}
catch(NotFoundNodeExeption ex){
cerr << ex.what() << endl;
}
cout << "проверка конструктора копирования" << endl;
cout << endl << endl << endl;
intTree1.inorder_walk(intTree1.get_root());
cout << endl << endl << endl;
Tree<double> dTree;
dTree << 8.4;
dTree << 3.3;
dTree << 10.5;
dTree << 1.56;
dTree << 6.2;
dTree << 4.76;
dTree << 7.9;
dTree << 14.4;
dTree << 13.1;
cout << endl << endl;
cout << "все листья дерева дабл" << endl;
dTree.inorder_walk(dTree.get_root());
Tree<Student> sTree;
Student s1(84,"Semenov");
Student s2(33,"Bondarenko");
Student s3(105,"Saenko");
Student s4(15,"Tyrel");
Student s5(62,"Snow");
Student s6(47,"Stark");
Student s7(79,"Barateon");
Student s8(144,"Targarien");
Student s9(131,"Marmont");
sTree << s1;
sTree << s2;
sTree << s3;
sTree << s4;
sTree << s5;
sTree << s6;
sTree << s7;
sTree << s8;
sTree << s9;
cout << "все листья дерева студенты" << endl;
sTree.inorder_walk(sTree.get_root());
cout << endl;
cout << "удаление студента Баратеон" << endl;
sTree >> sTree.find_node(sTree.get_root(), s7);
sTree.inorder_walk(sTree.get_root());
}