С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 05.09.2015
Сообщений: 14
1

Параллельные вычисления с обменом сообщений

25.10.2016, 13:21. Показов 627. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте многоуважаемые. Если вдруг кто разбирается в этом вопросе - прошу вашей помощи.
В программе создается квадратная матрица, далее по строкам и по столбцам она записывается в одномерные массивы, в которых позже происходит поиск соседних одинаковых элементов.
Нужно распараллелить эти процессы(процесс записи в массивы и поиск одинаковых элементов), а я не понимаю, как это сдеать, чтобы работало адекватно?

Заранее благодарна за любые советы.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#include "stdafx.h"
#include <iostream>
#include <string>
#include <ctime>  
#include <omp.h>
 
using namespace std;
 
//Функция для сравнения элементов массива
int calc_numb(int *array, int count) {
    int j;
    int k = 0;
    for (j = 0; j < count - 1; j++) {
        if (array[j] == array[j + 1]) {
            k++;
        }
    }
    return k;
}
 
 
int main()
{
    int i,j;
    int count;
    srand(time(NULL));
    
//Ввод квадратной матрицы
    cout << "Enter the dimensions of a square matrix: ";
    cin >> count;
    int **arr = new int*[count];
 
    for (i = 0; i < count; i++) {
    arr[i] = new int[count];
    for (j = 0; j < count; j++) {
    arr[i][j] = rand() % 3;
    cout << arr[i][j] << " ";
    }
    cout << "\n";
    }
 
    
//Запись столбцов матрицы в одномерные массивы
    int *array = 0;
    cout << endl << "Column arrays:" << endl;
    for (j = 0; j < count; j++) {
        array = new int[count];
        for (i = 0; i < count; i++) {
            array[i] = arr[i][j];
        cout <<"Array"<<i<<" "<< array[i];
        cout << endl;
                            }
        int k =calc_numb(array, count);
        cout << k<<endl;
 
    }
 
//Запись строк матрицы в одномерные массивы
        cout << endl << "Row arrays:" << endl;
 
        for (i = 0; i < count; i++) {
            array = new int[count];
 
                for (j = 0; j < count; j++) {
 
                array[j] = arr[i][j];
                cout << "Array" << j << " " << array[j];
                cout << endl;
                
 
            }
                int l = calc_numb(array, count);
                cout << l << endl;
        }
        cout << endl << "Runtime = " << clock() / 1000.0 << endl;
    system("pause");
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.10.2016, 13:21
Ответы с готовыми решениями:

Параллельные вычисления
Нужно использовать параллельные вычисления, при решении данной задачи, пробовал распараллелить...

Параллельные вычисления
Прошу помочь решить следующую задачу(параллельное программирование) Дана последовательность чисел....

Параллельные вычисления
Здравствуйте! Нужно перебрать целые числа от M до N и найти первое попавшееся число, подходящее под...

Параллельные вычисления
Имеется код, который проверяет число j на простоту: using System; using...

1
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,628
25.10.2016, 13:47 2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#include "stdafx.h"
#include <iostream>
#include <string>
#include <ctime>  
#include <amp.h>
 using namespace concurrency;
using namespace std;
 
//Функция для сравнения элементов массива
int calc_numb(int *array, int count) {
    int j;
    int k = 0;
    for (j = 0; j < count - 1; j++) {
        if (array[j] == array[j + 1]) {
            k++;
        }
    }
    return k;
}
 
 
int main()
{
    int i,j;
    int count;
    srand(time(NULL));
    
//Ввод квадратной матрицы
    cout << "Enter the dimensions of a square matrix: ";
    cin >> count;
    int **arr = new int*[count];
 
    for (i = 0; i < count; i++) {
    arr[i] = new int[count];
    for (j = 0; j < count; j++) {
    arr[i][j] = rand() % 3;
    cout << arr[i][j] << " ";
    }
    cout << "\n";
    }
 
    
//Запись столбцов матрицы в одномерные массивы
    int *array = 0;
    cout << endl << "Column arrays:" << endl;
//    for (j = 0; j < count; j++) 
    parallel_for (int (0), count, [&](int j)
    {
        array = new int[count];
        for (i = 0; i < count; i++) {
            array[i] = arr[i][j];
        cout <<"Array"<<i<<" "<< array[i];
        cout << endl;
                            }
        int k =calc_numb(array, count);
        cout << k<<endl;
 
    });
 
//Запись строк матрицы в одномерные массивы
        cout << endl << "Row arrays:" << endl;
 
//        for (i = 0; i < count; i++) 
            parallel_for (int (0), count, [&](int i)
        {
            array = new int[count];
 
                for (j = 0; j < count; j++) 
                {
                 array[j] = arr[i][j];
                cout << "Array" << j << " " << array[j];
                cout << endl;
                }
                int l = calc_numb(array, count);
                cout << l << endl;
        });
        cout << endl << "Runtime = " << clock() / 1000.0 << endl;
    system("pause");
}
0
25.10.2016, 13:47
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.10.2016, 13:47
Помогаю со студенческими работами здесь

Параллельные вычисления.
Собственно взял себе тему на курсовой, решил попробовать реализовать это с помощью средств Java. Не...

Параллельные вычисления
Здравствуйте. Пишу курсовую,пришлось много что узнавать нового,так как параллельное...

Параллельные вычисления
Здравствуйте, не знаю в какой ветке постить, решил в этой. Хочу использовать эти технологии...

Параллельные вычисления средствами С++ 11
Поиск файлов в каталоге реализован в ф-ии direct, потоки управляют из мейна. Ф-ю direct надо...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS, Swagger и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru