-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathhuffmanCodingTree.cpp
More file actions
127 lines (118 loc) · 2.61 KB
/
Copy pathhuffmanCodingTree.cpp
File metadata and controls
127 lines (118 loc) · 2.61 KB
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
#include <iostream>
using namespace std;
class HuffmanBaseNode
{
public:
virtual ~HuffmanBaseNode() = default;
virtual bool isLeaf() const = 0;
virtual int getFrequency() const = 0;
virtual char getElement() = 0;
virtual HuffmanBaseNode *getLeft() = 0;
virtual HuffmanBaseNode *getRight() = 0;
};
class HuffmanLeafNode : public virtual HuffmanBaseNode
{
char element;
int frequency;
public:
HuffmanLeafNode() : element(0), frequency(0) {}
HuffmanLeafNode(char element, int frequency)
: element(element), frequency(frequency)
{
}
char getElement() override
{
return element;
}
HuffmanBaseNode *getLeft() override
{
return NULL;
}
HuffmanBaseNode *getRight() override
{
return nullptr;
}
int getFrequency() const override
{
return frequency;
}
bool isLeaf() const override
{
return true;
}
};
class HuffmanInternalNode : public virtual HuffmanBaseNode
{
int frequency;
HuffmanBaseNode *left;
HuffmanBaseNode *right;
public:
HuffmanInternalNode() : left(nullptr), right(nullptr), frequency(0) {}
HuffmanInternalNode(HuffmanBaseNode *l, HuffmanBaseNode *r, int frequency)
: left(l), right(r), frequency(frequency)
{
}
int getFrequency() const override
{
return frequency;
}
HuffmanBaseNode *getLeft() override
{
return left;
}
HuffmanBaseNode *getRight() override
{
return right;
}
char getElement() override
{
return '\0';
}
bool isLeaf() const override
{
return false;
}
};
class HuffmanCodingTree : public HuffmanBaseNode
{
HuffmanBaseNode *root;
public:
HuffmanCodingTree(char element, int frequency)
{
// std::cout << "1st " << element << frequency << "\n";
this->root = new HuffmanLeafNode(element, frequency);
}
HuffmanCodingTree(HuffmanBaseNode *l, HuffmanBaseNode *r, int frequency)
{
this->root = new HuffmanInternalNode(l, r, frequency);
}
~HuffmanCodingTree()
{
delete root;
}
HuffmanBaseNode *getRoot() const
{
return root;
}
// @TODO: keep an eye here
int getFrequency() const override
{
return root->getFrequency();
}
bool isLeaf() const override
{
return root->isLeaf();
}
char getElement() override
{
return root->getElement();
}
HuffmanBaseNode *getLeft() override
{
return root->getLeft();
}
HuffmanBaseNode *getRight() override
{
return root->getRight();
}
};