#include<vector>
using namespace std;
const int dim = 1000005;
int n, nr3, nr4, m, num, nrcomp, nrcic;
int r[dim], g[dim], viz[dim], t[dim], frst[dim], cic[dim];
vector<int> v[dim], g3, g4;
int rad(int x){
while(r[x] > 0){
x = r[x];
}
return x;
}
void upd(int nod){
if(g[nod] == 4){
nr3--;
nr4++;
g4.push_back(nod);
}
else if(g[nod] == 3){
nr3++;
g3.push_back(nod);
for(int i = 0; i < v[nod].size(); i++){
frst[ v[nod][i] ] = nod;
}
}
}
int verif(int nod){
if(nrcomp > 1){
return 0;
}
if(nrcomp == 1 && viz[nod] == 0){
return 0;
}
int i, n3 = 0;
if(g[nod] == 3){
n3++;
}
for(int i = 0; i < v[nod].size(); i++){
if(g[ v[nod][i] ] == 3){
n3++;
}
}
if(n3 != nr3){
return 0;
}
return 1;
}
void Init(int N) {
n = N;
for(int i = 0; i < n; i++){
r[i] = -1;
}
}
static void dfs(int nod, int tt){
t[nod] = tt;
for(int i = 0; i < v[nod].size(); i++){
if(v[nod][i] != tt){
dfs(v[nod][i], nod);
}
}
}
void Link(int x, int y) {
int r1, r2, nod;
g[x]++;
g[y]++;
if(g[x] == 3){
frst[y] = x;
}
if(g[y] == 3){
frst[x] = y;
}
upd(x);
upd(y);
r1 = rad(x);
r2 = rad(y);
m++;
if(r1 != r2){
if(r[r1] < r[r2]){
r[r1] += r[r2];
r[r2] = r1;
cic[r1] |= cic[r2];
}
else{
r[r2] += r[r1];
r[r1] = r2;
cic[r2] |= cic[r1];
swap(r1, r2);
}
}
else{
nrcic++;
if(nrcic == 1){
t[x] = -1;
dfs(x, -1);
nod = y;
while(nod != -1){
viz[nod] = 1;
nod = t[nod];
num++;
}
}
if(cic[r1] == 0){
nrcomp++;
cic[r1] = 1;
}
}
v[x].push_back(y);
v[y].push_back(x);
}
int CountCritical() {
if(nr4 > 1){
return 0;
}
if(nr4 == 1){
return verif(g4[0]);
}
if(nr3 > 3){
return 0;
}
if(nr3 != 0){
int nr = 0;
for(int i = 0; i < nr3; i++){
nr += verif(g3[i]);
int nod = g3[i];
for(int j = 0; j < v[nod].size(); j++){
if(frst[ v[nod][j] ] == nod && g[ v[nod][j] ] < 3){
nr += verif(v[nod][j]);
}
}
}
return nr;
}
if(nrcomp > 1){
return 0;
}
if(nrcomp == 1){
return num;
}
return n;
}
Compilation message
rings.cpp: In function 'void upd(int)':
rings.cpp:22:26: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = 0; i < v[nod].size(); i++){
~~^~~~~~~~~~~~~~~
rings.cpp: In function 'int verif(int)':
rings.cpp:38:22: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = 0; i < v[nod].size(); i++){
~~^~~~~~~~~~~~~~~
rings.cpp:34:9: warning: unused variable 'i' [-Wunused-variable]
int i, n3 = 0;
^
rings.cpp: In function 'void dfs(int, int)':
rings.cpp:58:22: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = 0; i < v[nod].size(); i++){
~~^~~~~~~~~~~~~~~
rings.cpp: In function 'int CountCritical()':
rings.cpp:128:30: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int j = 0; j < v[nod].size(); j++){
~~^~~~~~~~~~~~~~~
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
18 ms |
23808 KB |
Output is correct |
2 |
Correct |
21 ms |
24064 KB |
Output is correct |
3 |
Correct |
21 ms |
24064 KB |
Output is correct |
4 |
Correct |
18 ms |
24064 KB |
Output is correct |
5 |
Correct |
20 ms |
24064 KB |
Output is correct |
6 |
Correct |
21 ms |
24320 KB |
Output is correct |
7 |
Correct |
19 ms |
23968 KB |
Output is correct |
8 |
Correct |
20 ms |
24064 KB |
Output is correct |
9 |
Correct |
21 ms |
24064 KB |
Output is correct |
10 |
Correct |
22 ms |
24064 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
433 ms |
46456 KB |
Output is correct |
2 |
Correct |
859 ms |
58200 KB |
Output is correct |
3 |
Correct |
1037 ms |
69768 KB |
Output is correct |
4 |
Correct |
1100 ms |
70136 KB |
Output is correct |
5 |
Correct |
1101 ms |
75584 KB |
Output is correct |
6 |
Correct |
1225 ms |
96504 KB |
Output is correct |
7 |
Correct |
1025 ms |
72844 KB |
Output is correct |
8 |
Correct |
1000 ms |
64248 KB |
Output is correct |
9 |
Correct |
1076 ms |
66808 KB |
Output is correct |
10 |
Correct |
714 ms |
64760 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
18 ms |
23808 KB |
Output is correct |
2 |
Correct |
21 ms |
24064 KB |
Output is correct |
3 |
Correct |
21 ms |
24064 KB |
Output is correct |
4 |
Correct |
18 ms |
24064 KB |
Output is correct |
5 |
Correct |
20 ms |
24064 KB |
Output is correct |
6 |
Correct |
21 ms |
24320 KB |
Output is correct |
7 |
Correct |
19 ms |
23968 KB |
Output is correct |
8 |
Correct |
20 ms |
24064 KB |
Output is correct |
9 |
Correct |
21 ms |
24064 KB |
Output is correct |
10 |
Correct |
22 ms |
24064 KB |
Output is correct |
11 |
Incorrect |
20 ms |
24192 KB |
Output isn't correct |
12 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
18 ms |
23808 KB |
Output is correct |
2 |
Correct |
21 ms |
24064 KB |
Output is correct |
3 |
Correct |
21 ms |
24064 KB |
Output is correct |
4 |
Correct |
18 ms |
24064 KB |
Output is correct |
5 |
Correct |
20 ms |
24064 KB |
Output is correct |
6 |
Correct |
21 ms |
24320 KB |
Output is correct |
7 |
Correct |
19 ms |
23968 KB |
Output is correct |
8 |
Correct |
20 ms |
24064 KB |
Output is correct |
9 |
Correct |
21 ms |
24064 KB |
Output is correct |
10 |
Correct |
22 ms |
24064 KB |
Output is correct |
11 |
Incorrect |
20 ms |
24192 KB |
Output isn't correct |
12 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
18 ms |
23808 KB |
Output is correct |
2 |
Correct |
21 ms |
24064 KB |
Output is correct |
3 |
Correct |
21 ms |
24064 KB |
Output is correct |
4 |
Correct |
18 ms |
24064 KB |
Output is correct |
5 |
Correct |
20 ms |
24064 KB |
Output is correct |
6 |
Correct |
21 ms |
24320 KB |
Output is correct |
7 |
Correct |
19 ms |
23968 KB |
Output is correct |
8 |
Correct |
20 ms |
24064 KB |
Output is correct |
9 |
Correct |
21 ms |
24064 KB |
Output is correct |
10 |
Correct |
22 ms |
24064 KB |
Output is correct |
11 |
Correct |
433 ms |
46456 KB |
Output is correct |
12 |
Correct |
859 ms |
58200 KB |
Output is correct |
13 |
Correct |
1037 ms |
69768 KB |
Output is correct |
14 |
Correct |
1100 ms |
70136 KB |
Output is correct |
15 |
Correct |
1101 ms |
75584 KB |
Output is correct |
16 |
Correct |
1225 ms |
96504 KB |
Output is correct |
17 |
Correct |
1025 ms |
72844 KB |
Output is correct |
18 |
Correct |
1000 ms |
64248 KB |
Output is correct |
19 |
Correct |
1076 ms |
66808 KB |
Output is correct |
20 |
Correct |
714 ms |
64760 KB |
Output is correct |
21 |
Incorrect |
20 ms |
24192 KB |
Output isn't correct |
22 |
Halted |
0 ms |
0 KB |
- |