Cod sursa(job #3279104)

Utilizator Andercau_VasileAndercau Vasile Andercau_Vasile Data 21 februarie 2025 20:57:54
Problema Secventa 5 Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.79 kb
#include <fstream>
#include <unordered_map>
using namespace std;

ifstream fin("secv5.in");
ofstream fout("secv5.out");

#define NMAX 1050005

int v[NMAX];
unordered_map<int, int> M;

long long numar(int k, int n) {
    M.clear();
    long long cnt = 0;
    int i = 1;
    int nr = 0;
    for (int j = 1; j <= n; ++j) {
        M[v[j]]++;
        if (M[v[j]] == 1) {
            nr++;
        }
        while (nr > k) {
            M[v[i]]--;
            if (M[v[i]] == 0) {
                nr--;
            }
            i++;
        }
        cnt += j - i + 1;
    }
    return cnt;
}

int main() {
    int n, l, u;
    fin >> n >> l >> u;
    for (int i = 1; i <= n; ++i) {
        fin >> v[i];
    }

    fout << numar(u, n) - numar(l - 1, n);
    return 0;
}