이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define all(x) x.begin(),x.end()
#define sz(x) (int)(x.size())
const int MAXN = 1e6+10 ;
using namespace std ;
int N;
bool mem ;
vector<int> adj[MAXN] ;
vector< vector<int> > grafos , dsu ;
vector<int> sumiu ;
vector<bool> melou ;
bool suave = true ;
int find(int idx, int x) { return (dsu[idx][x] == x) ? x : find(idx,dsu[idx][x]) ; }
void join(int idx ,int x, int y){
x = find(idx, x) ;
y = find(idx,y ) ;
if(x ==y ){
melou[idx] = true ;
return ;
}
if(rand() % 2 ) swap(x,y);
dsu[idx][x] = y ;
}
void create(int val, int A, int B){
sumiu.push_back(val) ;
melou.push_back(false );
grafos.push_back(vector<int>(N,0)) ;
dsu.push_back(vector<int>(N)) ; iota(all(dsu.back()),0) ;
int idx = sz(sumiu)-1;
for(int i = 0 ; i < N ; i++ ){
if(i == val ) continue ;
for(auto e : adj[i]){
if(e == val ) continue ;
if(i == A && e == B ) continue ;
if(i == B && e == A ) continue ;
if( (++grafos[idx][i]) > 2 ) melou[idx] = true ;
if(i > e ) continue ;
join(idx,i,e) ;
}
}
}
void limpa(int i){
swap(sumiu[i], sumiu.back()) ;
swap(grafos[i] , grafos.back()) ;
swap(melou[i] , melou.back()) ;
swap(dsu[i] , dsu.back() ) ;
melou.pop_back() ;
sumiu.pop_back() ;
grafos.pop_back() ;
dsu.pop_back() ;
}
void Init(int N_) {
N = N_;
create(-1,-1,-1) ;
}
void Link(int A, int B) {
//significa que jah achei alguem com 4 ou mais
if(mem){
for(int i = 0 ; i < sz(sumiu) ; i++ ){
if(A == sumiu[i] || B == sumiu[i] ) continue ;
grafos[i][A]++ ;
grafos[i][B]++ ;
if(grafos[i][A] > 2 || grafos[i][B] > 2 ) melou[i] = true ;
join( i,A,B ) ;
}
return ;
}
adj[A].push_back(B) ;
adj[B].push_back(A) ;
if(sz(adj[B]) > sz(adj[A])) swap(A,B) ;
if(sz(adj[A]) > 3){
mem = true ;
for(int i = 0 ; i < sz(melou) ; i++ ) limpa(0) ;
create(A,-1,-1) ;
return ;
}
for(auto &e : {A,B} ){
if(sz(adj[e]) == 3){
if(sumiu[0] == -1 ){
limpa(0) ;
for(auto viz : adj[e]){
create(viz,A,B) ;
}
create(e,A,B) ;
suave = false ;
continue ;
}
sort(all(adj[e])) ;
for(int i = 0 ; i <sz(sumiu) ; i++ ){
if( find(all(adj[e]) , sumiu[i] )== adj[e].end() && sumiu[i] != e ){
limpa(i) ;
i-- ;
}
}
}
}
for(int i = 0 ; i < sz(sumiu) ; i++ ){
if(A == sumiu[i] || B == sumiu[i] ) continue ;
grafos[i][A]++ ;
grafos[i][B]++ ;
join(i,A,B) ;
if(grafos[i][A] > 2 || grafos[i][B] > 2 ) melou[i] = true ;
}
}
int CountCritical() {
/* for(int i = 0 ; i < sz(sumiu) ; i++ ){
if(sumiu[i] != 0 ) continue ;
for(auto e : dsu[i]) cout << e << " " ;
cout << endl ;
} */
int ans = 0 ;
for(int i = 0 ; i < sz(melou) ; i++ )
if(!melou[i]) ans++ ;
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... |