답안 #204888

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
204888 2020-02-27T12:18:45 Z MetB Languages (IOI10_languages) C++14
88 / 100
2064 ms 24280 KB
#include <bits/stdc++.h>
#include "grader.h"
#include "lang.h"

using namespace std;

int a[3][56][100000], b[3][100000];
int cnt[3][100000];
const int MOD = 100000;

void excerpt (int* E) {
    int n = 100;
    memset (cnt, 0, sizeof (cnt));
    std::set <int> s[3];
    
    for (int i = 0; i < 100; i++) {
        for (int j = 0; j < min (2, n - i); j++) {
            int val = 1;
            for (int k = 0; k <= j; k++)
                val = val * E[i+k] % MOD;
            cnt[j][val]++;
            s[j].insert (val);
        }
    }
    
    double mx = 0;
    int x = 0;
    
    for (int i = 0; i < 56; i++) {
        double points = 0;
        
        for (int k = 0; k < 2; k++) {
            for (int j : s[k]) {
                if (b[k][j]) points += cnt[k][j] * ((double) a[k][i][j] / b[k][j]) * (k + 1);
            }
        }
        
        if (mx < points) {
            mx = points;
            x = i;
        }
    }
    
    x = language (x);
    
    for (int i = 0; i < 100; i++) {
        for (int j = 0; j < min (2, n - i); j++) {
            int val = 1;
            for (int k = 0; k <= j; k++)
                val = val * E[i+k] % MOD;
            a[j][x][val]++;
            b[j][val]++;
        }
    }
}
# 결과 실행 시간 메모리 Grader output
1 Correct 1905 ms 24280 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Partially correct 2064 ms 24204 KB Output is partially correct - 80.52%