제출 #635302

#제출 시각아이디문제언어결과실행 시간메모리
635302pedroslreyLanguages (IOI10_languages)C++17
74 / 100
2779 ms6920 KiB
#include <bits/stdc++.h> #include "grader.h" #include "lang.h" using namespace std; using ld = long double; const int MAXN = 65545; const int LANG = 66; const int SZ = 4; const int EPS = 2; int alfa[MAXN][LANG]; set<int> appear[LANG]; int tmp1[MAXN], tmp2[MAXN]; int cnt[LANG]; int iteration; void excerpt(int *E) { cerr << "\r" << iteration; ++iteration; for (int *it = E; it < E + 100; ++it) { ++tmp1[*it]; ++tmp2[*it]; } set<int> xs; for (int i = 0; i < 100-SZ; ++i) { bool ok = true; for (int j = i; j < i + SZ; ++j) if (tmp1[E[j]] >= EPS) ok = false; if (ok) { for (int j = i; j < i + SZ; ++j) --tmp2[E[j]]; i += 5; } else xs.insert(E[i]); } int guess = 1; ld best = 1e18; for (int i = 0; i < 56; ++i) { if (!cnt[i]) continue; ld val = 0; for (int k: xs) { ld x = ((ld)alfa[k][i])/cnt[i] - tmp2[k]; val += x*x; } for (int k: appear[i]) { if (xs.count(k)) continue; ld x = ((ld)alfa[k][i])/cnt[i] - tmp2[k]; val += x*x; } if (val < best) { best = val; guess = i; } } int lan = language(guess); for (int x: xs) { alfa[x][lan] += tmp2[x]; appear[lan].insert(x); } ++cnt[lan]; for (int *it = E; it < E + 100; ++it) { tmp1[*it] = 0; tmp2[*it] = 0; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...