Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 07.11.2020
Сообщений: 21

Отсортировать столбцы массива за суммой положительных модулей

12.06.2021, 16:43. Показов 1406. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, суть задания я описала в заголовке. В общем написала код, нашла сумму модулей положительных чисел в столбиках, но как-то когда дело дошло до сортировки - запуталась
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
 
namespace console_2D
{
    public struct Count
    {
        public double sum; // - сумма столбца
    }
    class Program
    {
        static void Main()
        {
            Console.InputEncoding = Encoding.Default;
            Console.OutputEncoding = Encoding.Default;
            Thread.CurrentThread.CurrentCulture = new System.Globalization.CultureInfo("en-US");
            Random rand = new Random();
 
            int n, k;
            Console.Write("Количество строк: ");
            while (!int.TryParse(Console.ReadLine(), out n) || n <= 0)
                Console.WriteLine("Ошибка ввода\nn = ");
 
            Console.Write("Количество столбиковв: ");
            while (!int.TryParse(Console.ReadLine(), out k) || k <= 0)
                Console.WriteLine("Ошибка ввода\nk = ");
            double[,] matrix = new double[n, k];
 
     
            Count[] sum_pos_colums = new Count[k];
            bool negative;
            int n_elements = 0;
            for (int i = 0; i < n; i++)
            {
                negative = true;
                for (int j = 0; j < k; j++)
                {
                    matrix[i, j] = Math.Round(rand.NextDouble() * (18.4 + 27.8) - 27.8, 1);
                    Console.Write($"{matrix[i, j]} ");
 
                    if (matrix[i, j] > 0)
                        negative = false;
                }
                Console.WriteLine();
 
                if (negative)
                    n_elements++;
            }
            Console.WriteLine($"Всего{n_elements} строк без положительных элементов .");
            for (int j = 0; j < k; j++)
            {
                for (int i = 0; i < n; i++)
                {
                    if (matrix[i, j] > 0)
                        sum_pos_colums[j].sum += (matrix[i, j]);
                }
                Console.WriteLine($"Сумма модулей положительных чисел {j+1} столбца= {sum_pos_colums[j].sum};");
 
 
            }
        }
    }
}
Нужно отсортировать столбики по модулю столбца по убыванию
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.06.2021, 16:43
Ответы с готовыми решениями:

Функция должна вычислять разницы между суммой положительных элементов массива и суммой модулей отрицательных элементов массива
Разработать функцию ,обрабатывающую массив и вычисляющую две величины.Кроме того,разработать две функции,которые вычисляют те же самые...

Определение разности между суммой модулей отрицательных элементов и суммой положительных элементов одномерного массива
Написать программу, определяющую разность между суммой модулей отрицательных элементов и суммой положительных элементов одномерного...

Определить разность между суммой модулей отрицательных элементов и суммой положительных
Написать программу, определяющую разность между суммой модулей отрицательных элементов и суммой положительных элементов одномерного...

3
 Аватар для zhunshun
767 / 495 / 216
Регистрация: 05.04.2015
Сообщений: 2,076
12.06.2021, 18:50
Цитата Сообщение от KristinaV Посмотреть сообщение
Нужно отсортировать столбики по модулю столбца по убыванию
А вы точно уверены что модули так считаютса? Модуль числа Math.Abs(num)
C#
1
2
3
4
5
6
7
8
9
10
11
12
    for (int i = 0; i < k; i++)
            {
                for (int j = 0; j < n; j++)
                {
                    for (int d = j + 1; d < n; d++)
                    if(sum_pos_colums[j].sum < sum_pos_colums[d].sum){
                        double temp = matrix[i, d];
                        matrix[i, d] = matrix[i, j];
                        matrix[i, j] = temp;
                    }
                }
            }
Так по вашим модулям
1
0 / 0 / 0
Регистрация: 07.11.2020
Сообщений: 21
12.06.2021, 22:01  [ТС]
Огромное спасибо за ответ! Ну я подумала что если модуль позитивного числа, то в принципе его можно и не искать, так как модуль позитивного числа это само позитивное число

Добавлено через 1 час 11 минут
У меня тут выводится ошибка
Code
1
Unhandled exception. System.IndexOutOfRangeException: Index was outside the bounds of the array.
И вот как не смотрела но не вижу из-за чего она появилась

Добавлено через 10 минут
Ошибка найдена но не пофикшена, код не будет работать если матрица не квадратная
0
 Аватар для zhunshun
767 / 495 / 216
Регистрация: 05.04.2015
Сообщений: 2,076
13.06.2021, 16:40
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
80
81
82
83
84
85
86
87
88
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
 
namespace console_2D
{
    public struct Count
    {
        public double sum; // - сумма столбца
    }
    public class Program
    {
        static Random rand = new Random();
        public static void Main()
        {
           /* Console.InputEncoding = Encoding.Default;
            Console.OutputEncoding = Encoding.Default;
            Thread.CurrentThread.CurrentCulture = new System.Globalization.CultureInfo("en-US");
            */
 
            int n, k;
            Console.Write("Количество строк: ");
            while (!int.TryParse(Console.ReadLine(), out n) || n <= 0)
                Console.WriteLine("Ошибка ввода\nn = ");
 
            Console.Write("Количество столбиковв: ");
            while (!int.TryParse(Console.ReadLine(), out k) || k <= 0)
                Console.WriteLine("Ошибка ввода\nk = ");
            double[,] matrix = new double[n, k];
 
     
            Count[] sum_pos_colums = new Count[k];
            bool negative;
            int n_elements = 0;
            for (int i = 0; i < n; i++)
            {
                negative = true;
                for (int j = 0; j < k; j++)
                {
                    matrix[i, j] = Math.Round(rand.NextDouble() * (18.4 + 27.8) - 27.8, 1);
                    Console.Write(matrix[i, j] + "\t");
 
                    if (matrix[i, j] > 0)
                        negative = false;
                }
                Console.WriteLine();
 
                if (negative)
                    n_elements++;
            }
            Console.WriteLine("Всего{0} строк без положительных элементов .", n_elements);
            for (int i = 0; i < n; i++)
            {
                for (int j = 0; j < k; j++)
                {
                    if (matrix[i, j] > 0)
                        sum_pos_colums[j].sum += (matrix[i, j]);
                }
                //Console.WriteLine("Сумма модулей положительных чисел {0} столбца= {1};", i +1, sum_pos_colums[i].sum);
            }
for (int i = 0; i < sum_pos_colums.Length; i++){
                Console.WriteLine("Сумма модулей положительных чисел {0} столбца= {1};", i +1, sum_pos_colums[i].sum);
            }
            for (int i = 0; i < n; i++)
            {
                for (int j = 0; j < k ; j++)
                {
                    for (int d = k - 1; d >= j + 1; --d)
                    if(sum_pos_colums[j].sum < sum_pos_colums[d].sum){
                        double temp = matrix[i, j];
                        matrix[i, j] = matrix[i,d];
                        matrix[i, d] = temp;
                    }
                }
            }
            for (int i = 0; i < n; i++)
            {
                for (int j = 0; j < k; j++)
                {
                    Console.Write(matrix[i, j] + "\t");
                }
                Console.WriteLine();
            }
        }
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.06.2021, 16:40
Помогаю со студенческими работами здесь

Найти разность между произведением всех положительных элементов массива и суммой модулей всех отрицательных
В массиве из 9 действительных чисел определить разность между произведением всех положительных элементов и суммой модулей всех...

В матрице удалить строки с несколькими максимумами и столбцы с заданной суммой элементов, 2-ю строку отсортировать
Приветствую всех форумчан и случайно заглянувших в эту тему! Как оказалось, слова: &quot;Помощь&quot;, &quot;решение&quot;,...

Первый элемент массива заменить суммой положительных элементов, последний - суммой четных отрицательных
в целочисленном массиве с n элементов первый элемент заменить суммой положительных элементов, а последний заменить суммой парных...

Найти разность между суммой положительных и суммой отрицательных элементов массива и возвести её в квадрат
Дан массив R(8) Найти разность между суммой положительных и суммой отрицательных элементов и возвести её в квадрат.

Дана матрица размера N×M. Поменять местами столбцы матрицы с min и max суммой положительных элементов
Здравствуйте задали написать код, и я не понимаю как сделать, всё что смог написал, но дальше я не понимаю. Нужно поменять местами...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru