Pagini recente » Cod sursa (job #757162) | Cod sursa (job #2059834) | Cod sursa (job #663388) | Cod sursa (job #2967130) | Cod sursa (job #2890472)
#include <bits/stdc++.h>
using namespace std;
ifstream in("secv5.in");
ofstream out("secv5.out");
int nrSecv(unsigned D, vector<unsigned int> v) {
unordered_map<unsigned int, int> map;
int j = 0, nr = 0;
int k = v.size();
for (int i = 0; i < k; i++) {
map[v[i]]++;
while (map.size() > D) {
map[v[j]]--;
if (map[v[j]] == 0) {
map.erase(map.find(v[j]));
}
j++;
}
nr += (i - j + 1);
}
return nr;
}
int main() {
int L, U, N;
in >> N >> L >> U;
int curent;
vector<unsigned int> inc;
for (int i = 0; i < N; ++i) {
in >> curent;
inc.push_back(curent);
}
out << nrSecv(U, inc) - nrSecv(L - 1, inc);
in.close();
out.close();
return 0;
}