Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 29.10.2019
Сообщений: 43

Последовательный и параллельный перебор простых чисел

27.04.2020, 18:18. Показов 1657. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Реализовать последовательный и параллельный (с последовательным
перебором простых чисел) алгоритм поиска чисел имеющих не меньше 5
делителей.
Перед началом поиска таких чисел должны задаваться количество потоков и
объем данных (предельное максимальное число для поиска чисел имеющих не
меньше 5 делителей). В качестве результата выводятся найденные числа с
количеством их делителей, а также анализ быстродействия.
При последовательном способе элементы массива обрабатываются в одном
потоке, при параллельном – в m потоках (параметр m должен передаваться в
функцию обработки). Реализовать распределение итераций цикла между потоками
двумя способами:
 статический способ - распределение итераций до начала выполнения
цикла. При заданном значении m итерации цикла делятся на блоки
фиксированного размера и эти блоки распределяются между потоками до
начала выполнения цикла;
 динамический способ распределения итераций. До начала выполнения
цикла потокам выделяются блоки итераций размера t (если поле t не
указано, то полагается значение t=1 ). Дальнейшее выделение итераций
(также блоками размера t) осуществляется в момент завершения
потоками своих ранее назначенных итераций.
Выполнить анализ быстродействия алгоритмов при разном объеме данных,
разном числе потоков; Время выполнения функции обработки должно измеряться
нахождением разницы между временем начала и временем окончания обработки.
Рассчитать ускорение и эффективность выполнения алгоритмов.
Вроде написал последовательный алгоритм, но чет не знаю как правильно его распараллелить: есть две функции и не понятно какую лучше отдать потокам? Или есть более правильная реализация в одной подпрограмме?
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
using System;
using System.Threading;
 
    class Program
    {
    static int x = 2;
    static int y = 15;
    public static bool IsPrime(int number)
    {
        if (number <= 1) return false;
        if (number == 2) return true;
        if (number % 2 == 0) return false;
 
        var boundary = (int)Math.Floor((number));
 
        for (int i = 3; i <= boundary; i += 2)
            if (number % i == 0)
                return false;
 
        return true;
    }
 
    static int nDivisors(int n)
        {
            int cnt = 0;
            for (int i = 1; i <= n; i++)
                if (n % i == 0)
                    cnt = cnt + 1;
            return cnt;
        }
 
    static void Main()
        {
            Console.WriteLine("Последовательно In range from " + x + " to " + y + ":");
            for (int i = x; i <= y; i++)
            {
                if (IsPrime(i) == false)
                { 
                    int t = nDivisors(i * i);
                    if (t > 5)
                        Console.WriteLine("N = " + i + " " + " in power of 2 has " + t + " divisors");
                }
            }
           
        }
    }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.04.2020, 18:18
Ответы с готовыми решениями:

Преобразовать последовательный код в параллельный
приветствую! Мой вопростак и не решен. Во-первых я не знал, как называется то, что мне нужно. Ну и те к кому я обращался, так же не...

Преобразовать последовательный код из com-porta в параллельный 4 битный
Научился подавать биты через компорт. Хочу с компьютера управлять 12 релюшками. В каждый момент времени - работает лишь одна из них....

Последовательный перебор коллекции
Добрый день! Можете подскать, как решить задачу (только сегодня познакомился с mongoDB). Для построения графика необходимо...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.04.2020, 18:18
Помогаю со студенческими работами здесь

как сделать последовательный перебор по записям в таблице?
Уважаемые программисты! Поможите кто может! Мне нужно сделать последовательный перебор по записям в таблице с помощью метода Locate. Пишу...

Как организовать последовательный перебор файлов в каталоге, для их чтения?
Не подскажет ли кто, как организовать последовательный перебор файлов в каталоге, для их чтения. Спасибо.

Нахождение простых, взаимно-простых и парно-простых чисел из указанного диапазона
Нужна помощь мне нужно создать программу для нахождение простых,взаимнопростых и парно простых чисел из указанного диапазона. у меня...

Найти первые десять простых чисел (остаток от деления простых целых)
procedure TForm1.Button1Click(Sender: TObject); var i, k, count, primes: word; n:integer; begin n:=strtoint(edit1.text);; k :=...

Параллельный генератор псевдослучайных чисел, на базе четырех линейных конгруэнтных генераторов
Всем доброе время суток)) У меня такая задачка: Нужно реализовать параллельный генератор псевдослучайных чисел, на базе четырех...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru