Cod sursa(job #2764315)

Utilizator marcumihaiMarcu Mihai marcumihai Data 20 iulie 2021 13:14:26
Problema Secventa 5 Scor 50
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.75 kb
#include <bits/stdc++.h>

using namespace std;

ifstream f ("secv5.in");
ofstream g ("secv5.out");

int n;
unsigned v[1500005];
int st, dr;
int L[1000005];
int rez (long long x)
{
    unordered_map <long long, int> fr;
    int cont=0;
    int sum=0;
    for(int i=0; i<=n; ++i)
        L[i]=0;
    int j=1;
    for(int i=1; i<=n; ++i)
    {

        fr[v[i]]++;

        while(fr.size()>x)
        {
            --fr[v[j]];
            if(fr[v[j]]==0)
            {
                fr.erase(v[j]);
            }

            ++j;
        }
        sum+=(i-j+1);



    }


    return sum;
}


int main()
{
    f>>n>>st>>dr;
    for(int i=1; i<=n; ++i)
        f>>v[i];


    g<<rez(dr)-rez(st-1);
    return 0;
}