-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfinite_automata.h
50 lines (35 loc) · 1.25 KB
/
finite_automata.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
#ifndef DFA_FINITE_AUTOMATA_H
#define DFA_FINITE_AUTOMATA_H
#include <vector>
#include <set>
#include <map>
#include <string>
template<typename T>
class FiniteAutomata {
protected:
class string {
private:
std::string internal_string;
public:
static std::vector<std::string>
to_string_conversion(std::vector<FiniteAutomata<T>::string> const &FA_string_vector);
explicit string(std::string _string) : internal_string(std::move(_string)) {};
std::string get_internal_string();
int length();
bool operator<(string const &other_string) const;
string operator+(char const &character) const;
friend std::ostream& operator<<(std::ostream& output_stream, const string &_string)
{
output_stream << _string.internal_string;
return output_stream;
}
};
int initial_state{}, alphabet_number{};
std::set<int> final_states;
std::map<int, std::vector<T>> transition_graph;
FiniteAutomata(int _init_state, int _alphabet_number, std::set<int> &_final_states,
std::map<int, std::vector<T>> &_transition_graph);
bool is_state_final(int _state);
T transition_function(int _current_state, int _alphabet_letter);
};
#endif