Submission #357572

# Submission time Handle Problem Language Result Execution time Memory
357572 2021-01-24T06:52:15 Z daniel920712 Parachute rings (IOI12_rings) C++14
20 / 100
4000 ms 42732 KB
#include <stdio.h>
#include <stdlib.h>
#include <vector>
using namespace std;
int N;
int who;
vector < int > Next[1000005];
int deg[1000005];
int big[1000005];
int con[1000005];
int tt=0;
bool have[1000005];
int ok=1;
void Init(int N_)
{
    N = N_;
}

void Link(int A, int B)
{
    Next[A].push_back(B);
    Next[B].push_back(A);
    if(deg[A]==2)
    {
        tt++;
        for(auto i:Next[A]) con[i]++;
    }
    if(deg[A]==3)
    {
        for(auto i:Next[A]) if(i!=B) con[i]--;
    }

    if(deg[B]==2)
    {
        tt++;
        for(auto i:Next[B]) con[i]++;
    }
    if(deg[B]==3)
    {
        for(auto i:Next[B]) if(i!=A) con[i]--;
    }
    deg[A]++;
    deg[B]++;

}
void F(int here)
{
    int t=0;
    have[here]=1;
    for(auto i:Next[here]) if(!have[i]&&i!=who) F(i);
}
int CountCritical()
{
    int ans=0;
    int i,j;
    for(i=0;i<N;i++)
    {
        ok=1;
        who=i;
        //printf("%d %d %d\n",i,con[i],tt);
        if(deg[i]>=3)
        {
            if(tt-con[i]>1) continue;
        }
        else if(tt-con[i]) continue;

        //printf("aa %d\n",i);
        for(auto j:Next[i]) deg[j]--;
        if(ok)
        {
            for(j=0;j<N;j++) have[j]=0;
            have[i]=1;
            for(j=0;j<N;j++)
            {
                if(deg[j]==0) have[j]=1;
                if(deg[j]==1&&!have[j]) F(j);
                if(deg[j]>=3&&i!=j) ok=0;
            }
            for(j=0;j<N;j++) if(!have[j]) ok=0;
        }

        for(auto j:Next[i]) deg[j]++;
        ans+=ok;
    }
    return ans;

}

Compilation message

rings.cpp: In function 'void F(int)':
rings.cpp:48:9: warning: unused variable 't' [-Wunused-variable]
   48 |     int t=0;
      |         ^
# Verdict Execution time Memory Grader output
1 Correct 16 ms 23788 KB Output is correct
2 Correct 18 ms 24044 KB Output is correct
3 Correct 19 ms 24044 KB Output is correct
4 Correct 35 ms 23788 KB Output is correct
5 Correct 180 ms 23916 KB Output is correct
6 Correct 611 ms 24300 KB Output is correct
7 Correct 17 ms 23916 KB Output is correct
8 Correct 118 ms 24028 KB Output is correct
9 Correct 19 ms 24044 KB Output is correct
10 Correct 18 ms 24044 KB Output is correct
# Verdict Execution time Memory Grader output
1 Execution timed out 4097 ms 42732 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 16 ms 23788 KB Output is correct
2 Correct 18 ms 24044 KB Output is correct
3 Correct 19 ms 24044 KB Output is correct
4 Correct 35 ms 23788 KB Output is correct
5 Correct 180 ms 23916 KB Output is correct
6 Correct 611 ms 24300 KB Output is correct
7 Correct 17 ms 23916 KB Output is correct
8 Correct 118 ms 24028 KB Output is correct
9 Correct 19 ms 24044 KB Output is correct
10 Correct 18 ms 24044 KB Output is correct
11 Execution timed out 4097 ms 23916 KB Time limit exceeded
12 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 16 ms 23788 KB Output is correct
2 Correct 18 ms 24044 KB Output is correct
3 Correct 19 ms 24044 KB Output is correct
4 Correct 35 ms 23788 KB Output is correct
5 Correct 180 ms 23916 KB Output is correct
6 Correct 611 ms 24300 KB Output is correct
7 Correct 17 ms 23916 KB Output is correct
8 Correct 118 ms 24028 KB Output is correct
9 Correct 19 ms 24044 KB Output is correct
10 Correct 18 ms 24044 KB Output is correct
11 Execution timed out 4097 ms 23916 KB Time limit exceeded
12 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 16 ms 23788 KB Output is correct
2 Correct 18 ms 24044 KB Output is correct
3 Correct 19 ms 24044 KB Output is correct
4 Correct 35 ms 23788 KB Output is correct
5 Correct 180 ms 23916 KB Output is correct
6 Correct 611 ms 24300 KB Output is correct
7 Correct 17 ms 23916 KB Output is correct
8 Correct 118 ms 24028 KB Output is correct
9 Correct 19 ms 24044 KB Output is correct
10 Correct 18 ms 24044 KB Output is correct
11 Execution timed out 4097 ms 42732 KB Time limit exceeded
12 Halted 0 ms 0 KB -