Submission #357243

# Submission time Handle Problem Language Result Execution time Memory
357243 2021-01-24T03:27:21 Z daniel920712 Parachute rings (IOI12_rings) C++14
0 / 100
3147 ms 74252 KB
#include <stdio.h>
#include <stdlib.h>
#include <vector>
using namespace std;
int N;
int who;
vector < int > Next[1000005],tt;
int deg[1000005];
bool have[1000005];
int ok=1;
int x=0,y=0,z=0;
void Init(int N_)
{
    N = N_;
}

void Link(int A, int B)
{
    Next[A].push_back(B);
    Next[B].push_back(A);
    deg[A]++;
    deg[B]++;
}
void F(int here)
{
    y++;
    int t=0;
    have[here]=1;
    for(auto i:Next[here]) if(!have[i]&&i!=who) F(i);
}
int CountCritical()
{
    int ans=0,now=0;
    int i,j;
    tt.clear();
    for(i=0;i<N;i++)
    {
        if(deg[i]>=3)
        {
            tt.push_back(i);
            now++;
        }
    }
    if(now==0)
    {
        x=y=0;
        ok=1;
        who=i;
        for(j=0;j<N;j++) have[j]=0;
        for(j=0;j<N;j++)
        {
            if(deg[j]==0) have[j]=1;
            if(deg[j]==1&&!have[j]) F(j);
        }
        for(j=0;j<N;j++)
        {
            if(!have[j])
            {
                who=-1;
                x++;
                y=0;
                F(j);
            }
            ans+=x;
        }

        if(x==0) return N;
        if(x==1) return y;
        return 0;
    }
    else if(now==1)
    {
        //printf("bb %d\n",ans);
        for(auto i:tt)
        {
            ok=1;
            who=i;
            for(auto j:Next[i]) deg[j]--;
            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;
        }
        if(deg[tt[0]]==3)
        {
            for(auto i:Next[tt[0]])
            {
                ok=1;
                who=i;
                for(auto j:Next[i]) deg[j]--;
                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;
    }
    else if(now==2)
    {
        for(auto i:tt)
        {
            ok=1;
            who=i;
            for(auto j:Next[i]) deg[j]--;
            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;
        }

        if(deg[tt[0]]==3)
        {
            for(auto i:Next[tt[0]])
            {
                ok=1;
                who=i;
                for(auto j:Next[i]) deg[j]--;
                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;

            }
        }

        if(deg[tt[1]]==3)
        {
            for(auto i:Next[tt[1]])
            {
                ok=1;
                who=i;
                for(auto j:Next[i]) deg[j]--;
                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;
    }
    else return 0;


}

Compilation message

rings.cpp: In function 'void F(int)':
rings.cpp:27:9: warning: unused variable 't' [-Wunused-variable]
   27 |     int t=0;
      |         ^
# Verdict Execution time Memory Grader output
1 Correct 16 ms 23788 KB Output is correct
2 Correct 19 ms 24044 KB Output is correct
3 Correct 19 ms 24044 KB Output is correct
4 Correct 16 ms 23824 KB Output is correct
5 Correct 20 ms 24064 KB Output is correct
6 Correct 18 ms 24172 KB Output is correct
7 Correct 22 ms 23916 KB Output is correct
8 Correct 22 ms 24044 KB Output is correct
9 Incorrect 24 ms 24044 KB Output isn't correct
10 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 597 ms 42648 KB Output is correct
2 Correct 1026 ms 52844 KB Output is correct
3 Correct 978 ms 57156 KB Output is correct
4 Correct 1305 ms 60316 KB Output is correct
5 Correct 1481 ms 60644 KB Output is correct
6 Correct 1450 ms 74252 KB Output is correct
7 Correct 991 ms 56668 KB Output is correct
8 Incorrect 3147 ms 57832 KB Output isn't correct
9 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 16 ms 23788 KB Output is correct
2 Correct 19 ms 24044 KB Output is correct
3 Correct 19 ms 24044 KB Output is correct
4 Correct 16 ms 23824 KB Output is correct
5 Correct 20 ms 24064 KB Output is correct
6 Correct 18 ms 24172 KB Output is correct
7 Correct 22 ms 23916 KB Output is correct
8 Correct 22 ms 24044 KB Output is correct
9 Incorrect 24 ms 24044 KB Output isn't correct
10 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 16 ms 23788 KB Output is correct
2 Correct 19 ms 24044 KB Output is correct
3 Correct 19 ms 24044 KB Output is correct
4 Correct 16 ms 23824 KB Output is correct
5 Correct 20 ms 24064 KB Output is correct
6 Correct 18 ms 24172 KB Output is correct
7 Correct 22 ms 23916 KB Output is correct
8 Correct 22 ms 24044 KB Output is correct
9 Incorrect 24 ms 24044 KB Output isn't correct
10 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 16 ms 23788 KB Output is correct
2 Correct 19 ms 24044 KB Output is correct
3 Correct 19 ms 24044 KB Output is correct
4 Correct 16 ms 23824 KB Output is correct
5 Correct 20 ms 24064 KB Output is correct
6 Correct 18 ms 24172 KB Output is correct
7 Correct 22 ms 23916 KB Output is correct
8 Correct 22 ms 24044 KB Output is correct
9 Incorrect 24 ms 24044 KB Output isn't correct
10 Halted 0 ms 0 KB -