Pagini recente » Cod sursa (job #1963298) | Cod sursa (job #2252924) | Cod sursa (job #3220842) | Cod sursa (job #1950802) | Cod sursa (job #2766781)
#include <fstream>
#include <unordered_map>
#include <algorithm>
using namespace std;
ifstream f("oite.in");
ofstream g("oite.out");
int n, l;
int v[1025];
unordered_map < int, int > M;
int main()
{
f >> n >> l;
for (int i = 1; i <= n; i++)
f >> v[i];
sort(v + 1, v + n + 1);
int ans = 0;
for (int i = 3; i < n; i++)
{
for (int j = 1; j < i - 1; j++)
M[v[i - 1] + v[j]]++;
for (int j = i + 1; j <= n; j++)
if (M.find(l - v[i] - v[j]) != M.end())
ans += M[l - v[i] - v[j]];
}
g << ans << "\n";
return 0;
}