-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathE28.h
79 lines (69 loc) · 1.27 KB
/
E28.h
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
#ifndef E28_H
#define E28_H
#include <string>
using std::string;
class TreeNode{
public:
TreeNode():value(string()), count(new int(1)), left(nullptr), right(nullptr) {}
TreeNode(const TreeNode&);
TreeNode& operator=(const TreeNode&);
~TreeNode();
private:
string value;
int* count;
TreeNode* left;
TreeNode* right;
};
class BinStrTree {
public:
BinStrTree():root(new TreeNode()) {}
BinStrTree(const BinStrTree& bt):root(new TreeNode(*bt.root)) {}
BinStrTree& operator=(const BinStrTree&);
~BinStrTree();
private:
TreeNode* root;
};
TreeNode::TreeNode(const TreeNode& tr){
value = tr.value;
++*count;
left = tr.left;
right = tr.right;
}
TreeNode& TreeNode::operator=(const TreeNode& tn){
++*tn.count;
if(--*count == 0){
delete count;
delete left;
delete right;
}
count = tn.count;
value = tn.value;
left = tn.left;
right = tn.right;
return *this;
}
TreeNode::~TreeNode(){
if(--*count == 0){
if(left){
delete left;
left = nullptr;
}
if(right){
delete right;
right = nullptr;
}
delete count;
count = nullptr;
}
}
BinStrTree& BinStrTree::operator=(const BinStrTree& bt){
// root = bt.root;
TreeNode* new_root = new TreeNode(*bt.root);
delete root;
root = new_root;
return *this;
}
BinStrTree::~BinStrTree(){
delete root;
}
#endif