Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.97/35: Рейтинг темы: голосов - 35, средняя оценка - 4.97
1 / 1 / 2
Регистрация: 21.09.2015
Сообщений: 321

Разбить массив на равные части

03.11.2015, 22:19. Показов 6944. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!
Нужно разбить массив А на m массивов равной длинны.
как лучше это сделать?
далее мне нужно
Потом c помощью потоков ( кол-во которых равно m) возвести элменты массива в степень.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
        private static void PowerArr(double[] a, int threadcount)
        {
            double[] b = new double[a.Length];
            for (var i = 0; i < threadcount; i++)
            {
               var th = new Thread(() =>
                {
                    for (int j = 0; j < a.Length; j++)
                        b[i] = Math.Pow(a[i], 1.789);
                });
                 th.start();
            }
          }
Добавлено через 1 час 37 минут
Сделал вот так,
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
        
            int[] n = {10, 100, 1000, 10000};
            int[] m = {2, 3, 4, 5, 10};
.....
 
    for (var i = 0; i < n.Length; i++)
            {
                Console.WriteLine("Кол-во элементов в массиве - {0}", n[i]);
                
                // цикл по потокам
                for (var l = 0; l < m.Length; l++)
                {
                    Console.WriteLine("Кол-во потоков - {0}", m[l]);
                    sw = Stopwatch.StartNew();
                    // цикл для поиска ср. времени
                    for (var j = 0; j < avg; j++)
                    {
                        PowerArr(A[i], m[l]);
                    }
 
                    sw.Stop();
                    ts = sw.Elapsed;
                    Console.WriteLine("Общее время: {0} миллисекунд", ts.TotalMilliseconds/avg);
                }
            }
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
        private static void PowerArr(double[] a, int threadcount)
        {
            var b = new double [threadcount] [];
            int n = a.Length/threadcount;
            var th = new Thread[threadcount];
          
            // делим массив
            for (var i = 0; i < threadcount; i++)
            {
                int  j = i*n;
                int  l = (i + 1)*n;
                
                if (l > a.Length)
                {
                    l = a.Length;
                }
                b[i] = new double[l - j];
                for (int k = j, p = 0; k < l; k++, p++)
                {
                    b[i][p] = a[k];
                }
 
            }
            // запускаем потоки
            for (var i = 0; i < threadcount; i++)
            {
                int j = i;
                th[i] = new Thread(() =>
                    {
                        for (var l = 0; l < b[j].Length; l++)
                            b[j][l] = Math.Pow(b[j][l], 1.789);
                    }
                  );
                th[i].Start();
            }
 
            foreach (var temp in th)
            {
                temp.Join();
            }
        }
мне кажется что кривовато..
и еще такой вопрос, у меня на компьютере 2 ядра, по идее должно максимально быстро работать при использовании 2 потоков, так и есть если размер массива мал, но при размере массива 10 000 - быстрее всего отрабатывает при 3.4.2 потоках
может я что то начудил с потоками...

Добавлено через 3 часа 20 минут
подниму...
почему то без поток и разбиении массива на части..код работает быстрее
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.11.2015, 22:19
Ответы с готовыми решениями:

Разбить массив на равные N части
Есть массив, например: int lines = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 }; мне надо разбить массив на 4 равных...

Разделить массив на две равные части, суммы элементов которых наиболее близки к равности
Мне нужно разделить массив на две равные части, суммы элементов которых наиболее близки к равности. Как разделить массив по на две части я...

Разбить массив на две части по четности индекса
Задан массив с количество элементов N. Сформировать два массива: в первый включить элементы исходного массива с четными номерами, а во...

5
03.11.2015, 22:22

Не по теме:

Цитата Сообщение от bySawka Посмотреть сообщение
почему то без поток и разбиении массива на части..код работает быстрее
ты познал истинную мультизадачность :D

0
1 / 1 / 2
Регистрация: 21.09.2015
Сообщений: 321
03.11.2015, 22:49  [ТС]
nestquik2, так а как сделать, что бы быстрее работало с потоками чем без них))
0
1 / 1 / 2
Регистрация: 21.09.2015
Сообщений: 321
03.11.2015, 22:59  [ТС]
2.rar
0
116 / 116 / 70
Регистрация: 10.11.2013
Сообщений: 445
04.11.2015, 01:28
bySawka, писать код на плюсах используя эти... как их.. не помню, как называют. Директивы сопроцессора, мэйби xD Крч, всякие-якие parallel for, barier и т.д.

Ну или как варик, в шарпике ансейв код пилить. Наверняка, там такие же фичи есть. погугли.
0
1 / 1 / 2
Регистрация: 21.09.2015
Сообщений: 321
04.11.2015, 12:26  [ТС]
Anderok, нужно именно через thread
Рекомендация к заданию
В функции потока необходимо предусмотреть возможность разбиения диапазона 0.. (N-1) на число потоков nThr. При запуске потока в качестве аргумента передается либо "индекс потока", определяющий область массива, который обрабатывается в данном потоке, либо начальный и конечный индексы массива.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.11.2015, 12:26
Помогаю со студенческими работами здесь

Не могу разбить массив на части
Забираю массив из файла (*.txt) (их ищет в папке и из внутренних данных должен собрать большой массив) сл вида: Двутавр СТО АСЧМ...

Разбивка изображения на равные части
Нужно разбить исходную картинку на 8 одинаковых прямоугольных частей и сохранить каждую часть в отдельный Jpeg, haalp :mda:

Разделение массива на две равные части
Заполняю массив размером 20 рандомными числами от 0 до 200. Надо разделить этот массив на две равные части. И эти части занести в массивы...

Разбить программу на 2 части
Входной язык содержит логические выражения, разделенные символом ; (точка с запятой). Логические выражения состоят из идентификаторов,...

Разбить файл на части
У меня есть текстовый документ весом 2.5 ГБ, можно ли разбить его на части не загружая его полностью в какую-либо переменную либо загружая...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru