закрыть?
void Task1Atomic(double** arr, long long N, int k, double& avg) {
double sum = 0;
#pragma omp parallel num_threads(k)
{
for (long long i = 0; i < N; ++i)
for (long long j = 0; j < N; ++j) {
arr[i][j] = sin(i) + cos(j);
#pragma omp atomic
sum += arr[i][j];
}
}
avg = sum / (N * N);
}
Он не общий, всё нормально
у каждого потока своя копия i j
прагма?
В каждому из arr[i][j] доступ имеет только один поток
а - понял
Дичь какая-то Почему не parallel for?
ну я люблю писать дичь в этот раз пишем дичь без параллел фор
Ну тогда страдай)
да лабу надо сделать так что страдаем
Нет Это же не параллел фор
Обсуждают сегодня