-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCTrieDec.hpp
40 lines (36 loc) · 1000 Bytes
/
CTrieDec.hpp
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
/*!
* \file CTrieDec.hpp
* \brief Klasse CTrieDec fuer Decodierung mittels Trie (Aufgabenteil 2)
*
* Dieses File enthaelt die Klasse CTrieDec, welche zur Decodierung mit Hilfe eines Tries in Aufgabe 2 benutzt wird.
*/
#ifndef CTRIEDEC_HPP_
#define CTRIEDEC_HPP_
#include "CDec.hpp"
#include "CKnot.hpp"
#include "CForwardCounter.hpp"
#include "CDoubleHashing.hpp"
/*!
* \class CTrieDec
* \brief Klasse fuer den Decoder mit Trie (Aufgabe 2)
*
* Klasse fuer den Decoder mittels Trie.
* CTrieDec erbt von CDec.
*/
class CTrieDec: public CDec {
private:
CKnot m_symbolTable[LZW_DICT_SIZE]; //!< Private Membervariable fuer das Dictionary.
public:
/*!
* parameterloser Konstruktor
*/
CTrieDec();
/*!
* decodiert den Vektor mit Hilfe des LZW-Algorithmus
* es wird dabei ein Trie als Dictionary benutzt
* @param encoded Vektor der zu decodierenden Indexwerte
* @return decodierter String
*/
string decode(const vector<unsigned int>& encoded);
};
#endif /* CTRIEDEC_HPP_ */