Răspuns :
#include <fstream>
#include <vector>
#include <numeric>
#include <algorithm>
int main()
{
std::ifstream fin("exista.in");
int k, m, n;
fin >> k >> m >> n;
std::vector<std::vector<int>> mat(n, std::vector<int>(m, 0));
for (int i = 0; i < m; ++i)
for (int j = 0; j < n; ++j)
fin >> mat[j][i];
fin.close();
std::ofstream fout("exista.out");
fout << std::accumulate(std::begin(mat), std::end(mat), 0,
[&mat, k] (int init, const std::vector<int> & vec) {
return init + (std::find(std::begin(vec), std::end(vec), k) != std::end(vec)) * (&vec - &mat[0] + 1);
});
}
Sau mai bine ia de aici indentat mai bine:
#include <vector>
#include <numeric>
#include <algorithm>
int main()
{
std::ifstream fin("exista.in");
int k, m, n;
fin >> k >> m >> n;
std::vector<std::vector<int>> mat(n, std::vector<int>(m, 0));
for (int i = 0; i < m; ++i)
for (int j = 0; j < n; ++j)
fin >> mat[j][i];
fin.close();
std::ofstream fout("exista.out");
fout << std::accumulate(std::begin(mat), std::end(mat), 0,
[&mat, k] (int init, const std::vector<int> & vec) {
return init + (std::find(std::begin(vec), std::end(vec), k) != std::end(vec)) * (&vec - &mat[0] + 1);
});
}
Sau mai bine ia de aici indentat mai bine: