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>
using namespace std;
#define int long long
#define REP(i,n) for(int i = 0; i < n; i ++)
#define FOR(i,a,b) for(int i = a; i < b; i ++)
#define vi vector<int>
#define pb push_back
#define SZ(v) (int)v.size()
#define remax(a,b) a = max(a,b)
#define remin(a,b) a = min(a,b)
#define all(v) v.begin(),v.end()
#define pii pair<int,int>
#define F first
#define S second
#define vpii vector<pii>
const int MX = 300005;
int n,m;
vpii adj[MX];
int cnt[MX];
int a[MX];
bool visvert[MX],viscol[MX];
vi gg[MX];
int cur;
void dfs(int u){
visvert[u] = 1;
cur++;
for(auto v:adj[u]){
if(visvert[v.F]) continue;
if(viscol[v.S]) dfs(v.F);
else gg[v.S].pb(v.F);
}
if(!viscol[a[u]]){
viscol[a[u]] = 1;
for(auto x:gg[a[u]]){
if(!visvert[x]) dfs(x);
}
}
}
vector<signed> find_reachable(vector<signed> r, vector<signed> u, vector<signed> v, vector<signed> c) {
n = SZ(r);
m = SZ(u);
REP(i,n) a[i] = r[i];
REP(i,m){
adj[u[i]].pb({v[i],c[i]});
adj[v[i]].pb({u[i],c[i]});
}
REP(i,n){
REP(j,n){
visvert[j] = 0;
viscol[j] = 0;
gg[j].clear();
}
cur = 0;
dfs(i);
cnt[i] = cur;
}
vector<signed> ans(n,0);
int mn = n;
REP(i,n) remin(mn,cnt[i]);
REP(i,n){
if(cnt[i] == mn) ans[i] = 1;
}
return ans;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |