제출 #985197

#제출 시각아이디문제언어결과실행 시간메모리
985197CrazyBotBoySequence (APIO23_sequence)C++17
11 / 100
2050 ms6712 KiB
#include "sequence.h"
#include <vector>
#include <unordered_map>
#include <algorithm>
#include <iostream>
#include <set>

using namespace std;

int sequence(int N, vector<int> A) {
    int maxOccurrences = 0;

    // Frequency array to count occurrences of each number
    vector<int> freq(N + 1, 0);

    // Iterate over each possible starting point of subarray
    for (int l = 0; l < N; ++l) {
        fill(freq.begin(), freq.end(), 0); // Reset frequency array for each new starting point
        vector<int> subarray;

        // Iterate over each possible ending point of subarray starting from 'l'
        for (int r = l; r < N; ++r) {
            subarray.push_back(A[r]);
            freq[A[r]]++;

            // Sort the current subarray to find medians
            vector<int> temp = subarray;
            sort(temp.begin(), temp.end());
            int k = temp.size();
            int median1 = temp[(k - 1) / 2];
            int median2 = temp[k / 2];

            maxOccurrences = max(maxOccurrences, freq[median1]);
            if (median1 != median2) {
                maxOccurrences = max(maxOccurrences, freq[median2]);
            }
        }
    }

    return maxOccurrences;
}
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...