Pagini recente » Cod sursa (job #360129) | Cod sursa (job #495433) | Cod sursa (job #2077421) | Cod sursa (job #2227705) | Cod sursa (job #2321749)
#include <fstream>
#include <unordered_map>
using namespace std;
ifstream fin("secv5.in");
ofstream fout("secv5.out");
unsigned int x[1<<20+1];
int n, l, u;
unordered_map<unsigned int, int>ap;
long long solve(int l)
{
ap.clear();
int j=1; long long sol=0;
for(int i=1; i<=n; ++i)
{
++ap[x[i]];
while(ap.size()>l)
{
--ap[x[j]];
if(ap[x[j]]==0) ap.erase(x[j]);
++j;
}
sol=sol+i-j+1;
}
return sol;
}
int main()
{
fin>>n>>l>>u;
for(int i=1; i<=n; ++i) fin>>x[i];
fout<<solve(u)-solve(l-1)<<"\n";
return 0;
}