# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
25071 | zigui | Potemkin cycle (CEOI15_indcyc) | C++14 | 26 ms | 3960 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<stdio.h>
#include<assert.h>
#include<vector>
#include<string.h>
#include<algorithm>
#include<memory.h>
#include<cmath>
#include<string>
#include<iostream>
#include<set>
#include<unordered_set>
#include<map>
#include<queue>
#include<functional>
#include<list>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
typedef pair<ll,ll> pll;
typedef pair<double, double> pdd;
typedef tuple<int,int,int> t3;
const int MX = 1005;
const int MM = 1000000007;
vector<int> G[MX];
bool H[MX][MX];
int a, b;
struct UF{
int t[MX];
int find(int x){
return t[x] ? t[x] = find(t[x]) : x;
}
int merge(int a, int b){
a = find(a), b = find(b);
return a == b ? 0 : (t[a] = b, 1);
}
void clear(){
memset(t, 0, sizeof(t));
}
} uf;
bool make_cycle(int x, int a, int b){
int dist[MX] = {}, prv[MX] = {};
dist[x] = 100;
queue<int> Q; Q.push(a); dist[a] = 1;
while(Q.size()){
int p = Q.front(); Q.pop();
for(int c : G[p]){
if( dist[c] ) continue;
dist[c] = dist[p] + 1; prv[c] = p;
Q.push(c);
}
}
vector<int> L;
L.push_back(x);
L.push_back(b);
while(b != a){
b = prv[b];
L.push_back(b);
}
for(int c : L) printf("%d ", c);
printf("\n");
return true;
}
bool check(int x, vector<int> &X){
for(int i = 0; i < X.size(); i++){
for(int j = i+1; j < X.size(); j++){
int &a = X[i], &b = X[j];
if( !H[a][b] ){
return make_cycle(x, a, b);
}
}
}
return false;
}
int main()
{
int N, M;
scanf("%d%d", &N, &M);
for(int i = 1; i <= M; i++){
scanf("%d%d", &a, &b);
G[a].push_back(b);
G[b].push_back(a);
H[a][b] = H[b][a] = 1;
}
for(int i = 1; i <= N; i++){
bool chk[MX] = {};
vector<int> L;
uf.clear();
for(int c : G[i]) L.push_back(c), chk[c] = 1;
chk[i] = 1;
for(int j = 1; j <= N; j++){
if( chk[j] == 0 ){
for(int c : G[j] ) uf.merge(j, c);
}
}
vector<int> group[MX];
for(int j = 1; j <= N; j++){
if( chk[j] ) group[uf.find(j)].push_back(j);
}
for(int j = 1; j <= N; j++){
if( check(i, group[j]) ) return 0;
}
}
printf("no\n");
}
Compilation message (stderr)
# | 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... |
# | 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... |