| # | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
|---|---|---|---|---|---|---|---|
| 250118 | rrrr10000 | 철인 이종 경기 (APIO18_duathlon) | C++14 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<ll,ll> P;
typedef tuple<ll,ll,ll> PP;
typedef vector<ll> vi;
typedef vector<vi> vvi;
typedef vector<vvi> vvvi;
#define rep(i,n) for(ll i=0;i<(ll)(n);i++)
#define REP(i,k,n) for(ll i=k;i<(ll)(n);i++)
#define pb push_back
#define eb emplace_back
#define fi first
#define se second
#define all(v) v.begin(),v.end()
const ll inf=1001001001001001;
const int mod=998244353;
template<class T> bool chmin(T&a,T b){if(a>b){a=b;return true;}return false;}
template<class T> bool chmax(T&a,T b){if(a<b){a=b;return true;}return false;}
template<class T> void out(T a){cout<<a<<endl;}
template<class T> void outv(T v){rep(i,v.size()){if(i)cout<<' ';cout<<v[i];}cout<<endl;}
template<class T> void outvv(T v){rep(i,v.size())outv(v[i]);}
vvp g;
vb used;
vi cnt;
ll sz,ans=0;
void scan(int i){
used[i]=true;
sz++;
for(auto x:g[i])if(!used[x.fi])scan(x.fi);
}
vi lk,ge;
ll c,ce,cv;
vb k;
void dfs(int i,int p,int e){
vp dl;
for(auto x:g[i])if(x.fi!=p){
if(id[x.fi]==-1){
id[x.fi]=c++;
dfs(x.fi,i,x.se);
if(p!=-1){
if(lk[x.fi]>=id[i])k[i]=true;
}
dl.pb(x);
}
else chmin(lk[i],id[x.fi]);
}
for(auto x:dl){
if(k){
if(lk[x.fi]>=id[i])ge[x.se]=ce++;
else ge[x.se]=
}
}
}
int main(){
ll n,m;cin>>n>>m;
g=vvp(n);
cnt=vi(n,1);
used=vb(n,false);
rep(i,m){
ll a,b;cin>>a>>b;a--;b--;
g[a].pb(b,i);g[b].pb(a,i);
}
rep(i,n){
if(used[i])continue;
sz=0;
scan(i);
// out(sz);
id[i]=0;
c=1;
dfs(i,-1,-1);
}
out(ans);
}
