제출 #512889

#제출 시각아이디문제언어결과실행 시간메모리
512889Markomafko972Languages (IOI10_languages)C++17
0 / 100
10092 ms33140 KiB
#include <bits/stdc++.h>
#include <stdlib.h>
#include <stdio.h>
#include "grader.h"
#include "lang.h"
using namespace std;
 
unordered_map<int, long long> m[60];
unordered_map<int, long long> m2[60];
set<long long> s;
vector<long long> v;
 
void excerpt(int *E) {
    s.clear();
    v.clear();
    for (int i = 0; i < 100; i++) {
    	E[i]--;
        s.insert(E[i]);
        if (i > 0) s.insert((long long)65535*(long long)E[i-1]+(long long)E[i]);
 
        if (i > 1) {
            long long u = E[i-2];
            u = u * (long long)65535 + (long long)E[i-1];
            u = u * (long long)65535 + (long long)E[i];
            s.insert(u);
        }
 
        if (i > 2 && (i <= 40 || i >= 90 || i % 2 == 0 || i % 3 == 0 || i % 5 == 0 || i % 7 == 0 || i % 11 == 0)) {
            long long u = E[i-3];
            u = u * (long long)65535 + (long long)E[i-2];
            u = u * (long long)65535 + (long long)E[i-1];
            u = u * (long long)65535 + (long long)E[i];
            s.insert(u);
        }
    }
    for (set<long long> :: iterator it = s.begin(); it != s.end(); it++) v.push_back(*it);
 
    int maxi = -1, koji = 0;
    for (int i = 0; i < 56; i++) {
        int kol = 0;
        for (int j = 0; j < v.size(); j++) {
            if (m[i].find(v[j]) != m[i].end()) {
        		if (v[j] > (long long)65535*(long long)65535) kol += m[i][v[j]];
				if (v[j] > (long long)65535*(long long)65535*(long long)65535) kol += m[i][v[j]];
                kol++;
            }
            //if (j > 1 && m[i][(long long)65535*(long long)65535*(long long)v[j-2]+(long long)65535*(long long)v[j-1]+(long long)v[j]]) kol++;
        }
 
        if (kol > maxi) {
            maxi = kol;
            koji = i;
        }
    }
 
    int pravi = language(koji);
    for (int i = 0; i < v.size(); i++) {
        m[pravi][v[i]]++;
        //if (i > 1) m[pravi][(long long)65535*(long long)65535*(long long)v[i-2]+(long long)65535*(long long)v[i-1]+(long long)v[i]]++;
    }
}

컴파일 시 표준 에러 (stderr) 메시지

lang.cpp: In function 'void excerpt(int*)':
lang.cpp:41:27: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   41 |         for (int j = 0; j < v.size(); j++) {
      |                         ~~^~~~~~~~~~
lang.cpp:57:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   57 |     for (int i = 0; i < v.size(); i++) {
      |                     ~~^~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...