답안 #271031

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
271031 2020-08-18T04:29:09 Z TMJN Languages (IOI10_languages) C++17
93 / 100
6088 ms 68444 KB
#pragma GCC target("avx2")
#pragma GCC optimize("O3")
#pragma GCC optimize("unroll-loops")
#include <bits/stdc++.h>
#include "grader.h"
using namespace std;

int k[56][66666];
map<pair<int,int>,vector<int>>mpv;
map<pair<int,pair<int,int>>,vector<int>>mppv;
map<pair<int,pair<int,pair<int,int>>>,vector<int>>mpppv;
int C[56];

void excerpt(int *E) {
	pair<double,int>mx={0,0};
	long long c[56];
	for(int i=0;i<56;i++){
		c[i]=0;
	}
	for(int i=0;i<100;i++){
		for(int j=0;j<56;j++){
			c[j]+=k[j][E[i]];
		}
	}
	for(int i=0;i<99;i++){
		for(int j:mpv[{E[i],E[i+1]}]){
			c[j]+=100;
		}
	}
	for(int i=0;i<98;i++){
		for(int j:mppv[{E[i],{E[i+1],E[i+2]}}]){
			c[j]+=10000;
		}
	}
	for(int i=0;i<97;i++){
		for(int j:mpppv[{E[i],{E[i+1],{E[i+2],E[i+3]}}}]){
			c[j]+=1000000;
		}
	}
	for(int i=0;i<56;i++){
		if(C[i]==0)continue;
		mx=max(mx,{(double)c[i]/C[i],i});
	}
	int l=language(mx.second);
	C[l]++;
	for(int i=0;i<100;i++){
		k[l][E[i]]++;
	}
	for(int i=0;i<99;i++){
		mpv[{E[i],E[i+1]}].push_back(l);
	}
	for(int i=0;i<98;i++){
		mppv[{E[i],{E[i+1],E[i+2]}}].push_back(l);
	}
	for(int i=0;i<97;i++){
		mpppv[{E[i],{E[i+1],{E[i+2],E[i+3]}}}].push_back(l);
	}
}
# 결과 실행 시간 메모리 Grader output
1 Correct 6036 ms 68368 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Partially correct 6088 ms 68444 KB Output is partially correct - 84.95%