diff options
| author | mzuenni <michi.zuendorf@gmail.com> | 2022-06-27 17:19:28 +0200 |
|---|---|---|
| committer | mzuenni <michi.zuendorf@gmail.com> | 2022-06-27 17:19:28 +0200 |
| commit | 5ab8a5088b729a9953b8dff1b2a985dc8fb2098b (patch) | |
| tree | ed40d6936c0e9eee40ba62751cbf99ecddbaddc2 /graph/connect.cpp | |
| parent | adabbad9c51cf7cd3874bfde8eac1fbcf84fec10 (diff) | |
updated tcr
Diffstat (limited to 'graph/connect.cpp')
| -rw-r--r-- | graph/connect.cpp | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/graph/connect.cpp b/graph/connect.cpp new file mode 100644 index 0000000..28a6f6c --- /dev/null +++ b/graph/connect.cpp @@ -0,0 +1,31 @@ +struct connect { + int n; + vector<pair<int, int>> edges; + LCT lct; // min LCT no updates required + + connect(int n, int m) : n(n), edges(m), lct(n+m) {} + + bool connected(int a, int b) { + return lct.connected(&lct.nodes[a], &lct.nodes[b]); + } + + void addEdge(int a, int b, int id) { + lct.nodes[id + n] = LCT::Node(id + n, id + n); + edges[id] = {a, b}; + if (connected(a, b)) { + int old = lct.query(&lct.nodes[a], &lct.nodes[b]); + if (old < id) eraseEdge(old); + } + if (!connected(a, b)) { + lct.link(&lct.nodes[a], &lct.nodes[id + n]); + lct.link(&lct.nodes[b], &lct.nodes[id + n]); + }} + + void eraseEdge(ll id) { + if (connected(edges[id].first, edges[id].second) && + lct.query(&lct.nodes[edges[id].first], + &lct.nodes[edges[id].second]) == id) { + lct.cut(&lct.nodes[edges[id].first], &lct.nodes[id + n]); + lct.cut(&lct.nodes[edges[id].second], &lct.nodes[id + n]); + }} +};
\ No newline at end of file |
