Submission #446550

#TimeUsernameProblemLanguageResultExecution timeMemory
446550ComPhyParkParachute rings (IOI12_rings)C++14
100 / 100
3794 ms123480 KiB
#include<cstdio> #include<vector> using namespace std; const int SZ = 1000010; int min(int a, int b) { return a < b ? a : b; } int n; const bool ifDebug = false; int cycleNum; vector<int>l[SZ]; typedef struct Graph { int st[4], ts[3]; int p[SZ], sz[SZ], ln[SZ]; bool is3E[SZ], isCX[SZ]; int x; void init() { x = n; st[0] = ts[0] = n; st[1] = st[2] = st[3] = ts[1] = ts[2] = 0; for (int i = 0; i < n; i++) { p[i] = i; sz[i] = 1; ln[i] = 0; is3E[i] = isCX[i] = false; } } void init(int X) { if (ifDebug)printf("init(%d)\n", X); init(); x = X; PR(); for (int i = 0; i < n; i++) { for (int e : l[i]) { if (e < i)Link(e, i); } } st[0] = st[1] = st[2] = st[3] = ts[1] = ts[2] = 0; for (int i = 0; i < n; i++) { st[min(gC(i), 3)]++; is3E[i] = false; } for (int i = 0; i < n; i++) { if (gC(i) > 2)is3E[f(i)] = true; } for (int i = 0; i < n; i++) { if (i == p[i])ts[gT(i)]++; } } int f(int a) { return a == p[a] ? a : p[a] = f(p[a]); } int gC(int A) { if (A == x)return 0; return l[A].size() - (isCX[A] ? 1 : 0); } void u(int A, int B) { int a = f(A), b = f(B); if (a != b) { p[b] = a; ts[gT(a)]--; ts[gT(b)]--; ln[a] += ln[b]; sz[a] += sz[b]; is3E[a] |= is3E[b]; } else { ts[gT(a)]--; } } void Con(int A, int B) { int a = f(A); if (x == n) { st[min(gC(A), 3)]--; l[A].push_back(B); st[min(gC(A), 3)]++; } else { st[min(gC(A) - 1, 3)]--; st[min(gC(A), 3)]++; } if (gC(A) >= 3)is3E[a] = true; } int gT(int a) { if (is3E[a]) { return 2; } else if (sz[a] == ln[a]) { return 1; } else { return 0; } } void Link(int A, int B) { if (A == x || B == x) { isCX[A + B - x] = true; return; } if (ifDebug)printf("%d:%d-%d\n", x, A, B); u(A, B); Con(A, B); Con(B, A); int a = f(A); ln[a]++; ts[gT(a)]++; } bool isChain() { return (ts[1] + ts[2] == 0); } void PR() { if (!ifDebug)return; printf("-------%d-------\n", x); printf("%d %d %d %d\n", st[0], st[1], st[2], st[3]); printf("%d %d %d\n", ts[0], ts[1], ts[2]); for (int a = 0; a < n; a++) { printf("(%d)", gC(a)); if (a == p[a]) { printf("[%d(%d,%d,%d)]", a, sz[a], gT(a), ln[a]); printf("\n"); } else { printf("%d->%d\n", a, f(a)); } } printf("-----------------\n"); } }Graph; Graph MG, GV[4]; int GS; void Init(int N) { cycleNum = n = N; MG.init(); } void Link(int A, int B) { bool p = (MG.st[3] == 0); MG.Link(A, B); for (int i = 0; i < GS; i++) { GV[i].Link(A, B); } if (MG.gT(MG.f(A)) == 1)cycleNum = MG.f(A); if (MG.gT(MG.f(B)) == 1)cycleNum = MG.f(B); if (p && MG.st[3]) { if (ifDebug)printf("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"); int a = A; if (l[A].size() < 3)a = B; GS = l[a].size() + 1; GV[l[a].size()].init(a); for (int i = 0; i < l[a].size(); i++) { GV[i].init(l[a][i]); } } } int CountCritical() { if (MG.ts[2]) { if (ifDebug)printf(">=3 Exists"); int r = 0; for (int i = 0; i < GS; i++) { if (GV[i].isChain())r++; } return r; } else if (MG.ts[1]) { if (ifDebug)printf("cycle Exists"); if (MG.ts[1] > 1)return 0; return MG.sz[cycleNum]; } else { if (ifDebug)printf("Already Chain"); return n; } }

Compilation message (stderr)

rings.cpp: In function 'void Link(int, int)':
rings.cpp:147:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  147 |   for (int i = 0; i < l[a].size(); i++) {
      |                   ~~^~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...