Pagini recente » Cod sursa (job #877339) | Cod sursa (job #1936742) | Cod sursa (job #2110203) | Cod sursa (job #141441) | Cod sursa (job #2894461)
#include <fstream>
#include <algorithm>
#include <unordered_map>
using namespace std;
ifstream fin("oite.in");
ofstream fout("oite.out");
const int N = 1024;
int v[N + 1];
unordered_map <int, int> f;
int main(){
int n, L;
fin >> n >> L;
for(int i = 1; i <= n; i++)
fin >> v[i];
sort(v + 1, v + n + 1); // DE CE ???
int ans = 0;
for(int i = 1; i <= n; i++){
for(int j = i + 1; j <= n; j++){
if(v[i] + v[j] > L)
break; // D ASTA
if(f.find(L - v[i] - v[j]) != f.end())
ans += f[L - v[i] - v[j]];
}
for(int j = 1; j < i; j++){
f[v[i] + v[j]]++;
}
}
fout << ans;
return 0;
}