Submission #505941

#TimeUsernameProblemLanguageResultExecution timeMemory
505941MurotYPaths (BOI18_paths)C++14
23 / 100
3102 ms14944 KiB
#include<bits/stdc++.h> #define ios ios::sync_with_stdio(0);cin.tie(0);cout.tie(0); #define ll long long #define ff first #define ss second using namespace std; const int N=2*1e5+7; vector <ll> g[N]; map <ll,ll> mp; ll c[N]; bool u[N], u1[N]; ll res=0, ans=0; void dfs(ll v){ u[v]=1; if (mp[c[v]] == 0) res++; else { u[v]=0; return ; } mp[c[v]]++; // cout << c[q] <<" " << c[v] << q <<"\n"; for (auto l:g[v]){ if (!u[l]){ dfs(l); } } u[v]=0; mp[c[v]]=0; return; } int main() { int n, m, k; cin >> n >> m >> k; for (int i=1;i<=n;i++) cin >> c[i]; for (int i=1;i<=m;i++){ int x, y; cin >> x >> y; g[x].push_back(y); g[y].push_back(x); } for (int i=1;i<=n;i++){ res=-1; mp.clear(); // fill(u1,u1+n+1, 0); dfs(i); // cout << res <<" "; ans+=res; } cout << ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...