diff options
Diffstat (limited to 'src/network_set.h')
-rw-r--r-- | src/network_set.h | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/src/network_set.h b/src/network_set.h new file mode 100644 index 0000000..e0ef043 --- /dev/null +++ b/src/network_set.h | |||
@@ -0,0 +1,28 @@ | |||
1 | #ifndef NETWORK_SET_H_3036B8E3 | ||
2 | #define NETWORK_SET_H_3036B8E3 | ||
3 | |||
4 | #include <map> | ||
5 | #include <optional> | ||
6 | #include <set> | ||
7 | #include <utility> | ||
8 | #include <vector> | ||
9 | |||
10 | class NetworkSet { | ||
11 | public: | ||
12 | void Clear(); | ||
13 | |||
14 | int AddLink(int id1, int id2); | ||
15 | |||
16 | bool IsItemInNetwork(int id) const; | ||
17 | |||
18 | int GetNetworkWithItem(int id) const; | ||
19 | |||
20 | const std::set<std::pair<int, int>>& GetNetworkGraph(int id) const; | ||
21 | |||
22 | private: | ||
23 | |||
24 | std::vector<std::set<std::pair<int, int>>> networks_; | ||
25 | std::map<int, int> network_by_item_; | ||
26 | }; | ||
27 | |||
28 | #endif /* end of include guard: NETWORK_SET_H_3036B8E3 */ | ||