Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
6 / 6 / 1
Регистрация: 25.02.2016
Сообщений: 342

Распараллеливание OMP для while

08.05.2020, 16:25. Показов 2238. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Ранее делал параллельную обработку для for.
Подскажите, каким образом делается распараллеливание для сортировки расческой, если там внешний цикл while?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
void combSort(int *arr, int n) {
    int gap = n;
    bool flag = true;
    
    while (gap != 1 || flag) {
        gap = (gap * 10) / 13;
        if (gap < 1)
            gap = 1;
        flag = false;
        for (int i = 0; i < n - gap; i++) {
            if (arr[i] > arr[i + gap]) {
                std::swap(arr[i], arr[i + gap]);
                flag = true;
            }
        }
    }
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.05.2020, 16:25
Ответы с готовыми решениями:

Распараллеливание потоков для нахождения суммы матрицы <omp.h>
Доброго дня. Сегодня слушал занимательную лекцию об распараллеливание потоков и получил задание: есть матрица 10,10 инициализированная...

Распараллеливание через omp.h
// labaOMP.cpp: определяет точку входа для консольного приложения. // #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include...

Распараллеливание алгоритма дейкстры для поиска кратчайших путей
Есть задача, она выполнена в последовательной программе ниже, помогите сделать её распараллеленый вариант ,что бы сравнить время выполнения...

5
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
08.05.2020, 16:43
Цитата Сообщение от Kertis138 Посмотреть сообщение
Подскажите, каким образом делается распараллеливание для сортировки расческой, если там внешний цикл while?
Не надо его раcпараллеливать. Цикл for распараллель
0
6 / 6 / 1
Регистрация: 25.02.2016
Сообщений: 342
08.05.2020, 17:13  [ТС]
То есть, этого достаточно для эффективной сортировки?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
void combSort(int *arr, int n) {
    int gap = n;
    bool flag = true;
 
    while (gap != 1 || flag) {
        gap = (gap * 10) / 13;
        if (gap < 1)
            gap = 1;
        flag = false;
 
        int i;
        #pragma omp parallel for private(i)
        for (i = 0; i < n - gap; i++) {
            #pragma omp critical
            if (arr[i] > arr[i + gap]) {
                std::swap(arr[i], arr[i + gap]);
                flag = true;
            }
        }
    }
}
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
08.05.2020, 17:23
Цитата Сообщение от Kertis138 Посмотреть сообщение
То есть, этого достаточно для эффективной сортировки?
Нет. Работать будет медленнее, чем в одном потоке.
А сортировку расчёсткой вообще можно распараллелить?
0
6 / 6 / 1
Регистрация: 25.02.2016
Сообщений: 342
08.05.2020, 17:55  [ТС]
В учебных планах фигурирует, значит, вероятно, что есть
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
08.05.2020, 17:59
Лучший ответ Сообщение было отмечено Kertis138 как решение

Решение

Цитата Сообщение от Kertis138 Посмотреть сообщение
В учебных планах фигурирует, значит, вероятно, что есть
Ага, только маловероятно.
Оставь так как сделано у тебя, думаю, проканает.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.05.2020, 17:59
Помогаю со студенческими работами здесь

Для распараллеливание процессов лучше пользоваться OpenMP или Win32?
Для распараллеливание процессов лучше пользоваться OpenMP или Win32? Называйте темы информативно

Директивы OMP
Работает ли {$omp parallel for} с foreach?

OMP parallel for
#pragma omp parallel for for (int j = 0; j &lt; whatFind.size(); j++) { string temp = &quot;&quot;; int t = Find(whatFind, 0,...

Не работает директива omp for
Здравствуйте! Проблема такая, программа создает параллельные потоки и в таком варианте #include &lt;iostream&gt; #include...

подключить библиотеку omp.h
Не получается подключить библиотеку omp.h. Прописывала в заголовке &quot;omp.h&quot;. Добавляла скаченный &quot;omp.h&quot;. Ничего не...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru