aboutsummaryrefslogtreecommitdiff
path: root/store/works/life/algorithm-experiment/3.2.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'store/works/life/algorithm-experiment/3.2.cpp')
-rw-r--r--store/works/life/algorithm-experiment/3.2.cpp100
1 files changed, 100 insertions, 0 deletions
diff --git a/store/works/life/algorithm-experiment/3.2.cpp b/store/works/life/algorithm-experiment/3.2.cpp
new file mode 100644
index 0000000..e4b8428
--- /dev/null
+++ b/store/works/life/algorithm-experiment/3.2.cpp
@@ -0,0 +1,100 @@
+#include <dlib/string.h>
+#include <dlib/string/string.h>
+#include <iostream>
+#include <istream>
+#include <map>
+#include <queue>
+#include <set>
+#include <string>
+
+std::map<std::string, std::vector<std::string>> graph;
+std::map<std::string, std::vector<std::string>> reverse_graph;
+
+int max_depth;
+std::string conflict;
+std::string conflict_parent;
+
+std::vector<std::string> list;
+
+void DFS(const std::string &current) {
+ for (auto i = list.cbegin(); i != list.cend(); ++i) {
+ if (*i == current) {
+ conflict_parent = current;
+ conflict = list.back();
+ return;
+ }
+ }
+
+ list.push_back(current);
+
+ if (list.size() > max_depth) {
+ max_depth = list.size();
+ }
+
+ if (list.size() == 18) {
+ for (const auto &s : list) {
+ std::cout << s << "->";
+ }
+ std::cout << "The End!!!" << std::endl;
+ }
+
+ for (const auto &s : graph[current]) {
+ DFS(s);
+ }
+
+ list.pop_back();
+}
+
+void DFS() {
+ for (const auto &[k, v] : reverse_graph) {
+ if (v.empty()) {
+ list.clear();
+ DFS(k);
+ }
+ }
+}
+
+std::vector<std::string> SplitBySpace(const std::string &s) {
+ std::vector<std::string> result;
+ int current_pos = 0;
+
+ while (true) {
+ auto p = s.find_first_of(" ", current_pos);
+ if (p == std::string::npos) {
+ result.push_back(std::string(s.cbegin() + current_pos, s.cend()));
+ break;
+ } else {
+ result.push_back(std::string(s.cbegin() + current_pos, s.cbegin() + p));
+ current_pos = p + 1;
+ }
+ }
+
+ return result;
+}
+
+int main() {
+ std::string s;
+ while (std::getline(std::cin, s)) {
+ auto result = SplitBySpace(s);
+
+ std::string parent = result.front();
+
+ graph[parent];
+ reverse_graph[parent];
+
+ for (auto i = result.cbegin() + 1; i != result.cend(); i++) {
+ graph[parent].push_back(*i);
+ reverse_graph[*i].push_back(parent);
+ }
+ }
+
+ std::cout << "We have " << graph.size() << " items.\n";
+ std::cout << "We have " << reverse_graph.size() << " parent items.\n";
+
+ DFS();
+
+ std::cout << conflict << "->" << conflict_parent << '\n';
+ std::cout << "Max depth: " << max_depth << '\n';
+
+ return 0;
+}