# | TimeUTC-0 | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
920343 | byunjaewoo | One-Way Streets (CEOI17_oneway) | C++17 | 147 ms | 262144 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#define int long long
using namespace std;
const int Nmax=100010;
int N, M, K, cnt, dfsn[Nmax], G[Nmax], ans[Nmax], Dep[Nmax], Par[20][Nmax], X[Nmax], Y[Nmax];
bool chk[Nmax];
vector<pair<int, int>> adj[Nmax], adj2[Nmax];
stack<pair<int, int>> S;
map<pair<int, int>, bool> mp;
int Find(int x) {return G[x]?(G[x]=Find(G[x])):x;}
void Union(int u, int v) {
u=Find(u), v=Find(v);
if(u!=v) G[u]=v;
}
int DFS(int curr, int prev) {
dfsn[curr]=++cnt;
int ret=cnt;
for(auto [next, w]:adj[curr]) if(next!=prev) {
if(dfsn[next]<dfsn[curr]) S.push({curr, next});
if(dfsn[next]) ret=min(ret, dfsn[next]);
else {
int tmp=DFS(next, curr);
ret=min(ret, tmp);
if(tmp>=dfsn[curr]) {
bool flag=false;
while(!S.empty() && S.top()!=make_pair(curr, next)) {
Union(S.top().first, S.top().second);
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |