0 / 0 / 0
Регистрация: 03.10.2022
Сообщений: 11

Переместить максимальный элемент матрицы F(k,p) в правый верхний угол, а минимальный элемент – в левый нижний

24.04.2023, 18:33. Показов 751. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, помогите решить задачу на C#
Переместить максимальный элемент матрицы F(k,p) в правый верхний угол, а минимальный элемент – в левый нижний.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.04.2023, 18:33
Ответы с готовыми решениями:

Переставляя строки и столбцы матрицы, переместить max (min) элемент в левый (правый) верхний (нижний) угол
Дана квадратная матрица порядка n*n . Переставляя её строки и столбцы, добиться того, чтобы max(min) элемент оказался в левом (правом)...

В матрице переставить набиольший элемент в верхний левый угол, а минимальный элемент в правый нижний угол
Помогите разобраться... Пишет ошибку, когда считывает элементы массива из файла. И еще куда вставить проверку, что файл пуст и что элементы...

Переместить минимальный элемент матрицы в правый нижний угол
Путем перестановки строк и столбцов переместить минимальный элемент массива F(M, M) в правый нижний угол. Const M=10; a=-2.7;...

8
643 / 338 / 139
Регистрация: 19.10.2013
Сообщений: 1,209
24.04.2023, 19:18
что не получается?
0
0 / 0 / 0
Регистрация: 11.11.2021
Сообщений: 20
24.04.2023, 20:21
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
int m = 10;
        int n = 10;
        int max = -1000;
        int min = 1000;
        Random rnd = new Random();
        int[,] arr = new int[m, n];
 
        for(int i =0 ; i < m; i++)
        {
            for(int j = 0; j <n ; j++)
            {
                arr[i,j] = rnd.Next(-100,100);
            }
        }
        for (int i = 0; i < m; i++)
        {
            for (int j = 0; j < n; j++)
            {
                if (arr[i,j] > max)
                {
                    max = arr[i, j];
                }
                if (arr[i,j] < min)
                {
                    min = arr[i, j];
                }
            }
        }
        arr[0, 0] = max;
        arr[(m - 1), (n - 1)] = min;

комментарии не нужны, думаю? код весьма лёгкий
0
3260 / 3306 / 556
Регистрация: 17.02.2019
Сообщений: 5,200
24.04.2023, 20:36
Цитата Сообщение от ssshurup Посмотреть сообщение
arr[0, 0] = max;
вроде в правый верхний угол максимальный перенести
Цитата Сообщение от ssshurup Посмотреть сообщение
arr[(m - 1), (n - 1)] = min;
а минимальный элемент – в левый нижний
0
0 / 0 / 0
Регистрация: 11.11.2021
Сообщений: 20
24.04.2023, 21:43
а, ну это я сначала прочитал, а потом начал писать, забылся, видимо). ну в целом, не критично поменять
0
 Аватар для Doomov
1056 / 335 / 119
Регистрация: 28.11.2020
Сообщений: 1,066
25.04.2023, 04:47
Цитата Сообщение от ssshurup Посмотреть сообщение
а, ну это я сначала прочитал, а потом начал писать, забылся, видимо). ну в целом, не критично поменять
Вы так считаете? И все таки где право и где лево?

Добавлено через 17 минут
ssshurup, с 15 строки я сделал бы так...
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
    var min = arr.Cast<int>().Min();
    var max = arr.Cast<int>().Max();
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < n; j++)
        {
            if (max == arr [i, j])
            {
                (arr [i, j], arr[0,n-1]) = (arr[0,n-1], arr [i, j]);
            }
            if (min == arr [i, j])
            {
                (arr [i, j], arr [m - 1, 0]) = (arr [m - 1, 0], arr [i, j]);
            }
        }
    }
А затем просто вывести результат.
1
 Аватар для iLinks
800 / 458 / 237
Регистрация: 03.01.2017
Сообщений: 1,339
25.04.2023, 12:40
Doomov, ну тогда можно и так
C#
1
2
3
4
var maxI = arr.Cast<int>().Select((v, i) => new { v, i }).Where(c => c.v == arr.Cast<int>().Max()).FirstOrDefault();
var minI = arr.Cast<int>().Select((v, i) => new { v, i }).Where(c => c.v == arr.Cast<int>().Min()).FirstOrDefault();
(arr[0, arr.GetLength(1)-1], arr[maxI.i / arr.GetLength(0), maxI.i % arr.GetLength(1)]) = (arr[maxI.i / arr.GetLength(0), maxI.i % arr.GetLength(1)], arr[0, arr.GetLength(1)-1]);
(arr[arr.GetLength(0)-1, 0], arr[minI.i / arr.GetLength(0), minI.i % arr.GetLength(1)]) = (arr[minI.i / arr.GetLength(0), minI.i % arr.GetLength(1)], arr[arr.GetLength(0)-1, 0]);
2
3260 / 3306 / 556
Регистрация: 17.02.2019
Сообщений: 5,200
25.04.2023, 18:35
Perth, ну еще пример
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
using System;
 
namespace ConsoleApp1
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // Переместить максимальный элемент матрицы F(k,p) в правый верхний угол, а минимальный элемент – в левый нижний.
            Console.Write("строки k = ");
            int k = Convert.ToInt32(Console.ReadLine());
            Console.Write("Столбцы p = ");
            int p = Convert.ToInt32(Console.ReadLine());
            int[,] F = new int[k, p];
            int max = int.MinValue;
            int min = int.MaxValue;
            Random rnd = new Random();
            for (int i = 0; i < F.GetLength(0); i++)
            {
                for (int j = 0; j < F.GetLength(1); j++)
                {
                    F[i, j] = rnd.Next(10, 100);
                    if (max < F[i, j]) max = F[i, j];
                    if (min > F[i, j]) min = F[i, j];
                }
            }
            PrintMatrix("Основная матрица", F); // метод вывода матрицы до изменения
            F[0, F.GetLength(1) - 1] = max; // заносим максимальный
            F[F.GetLength(0) - 1, 0] = min; // заносим минимальный
            PrintMatrix("Перенос в матрице", F); // метод вывода матрицы после изменения
            Console.ReadLine();
        }
 
        private static void PrintMatrix(string s, int[,] f)
        {
            Console.WriteLine(s);
            for (int i = 0; i < f.GetLength(0); i++)
            {
                for (int j = 0; j < f.GetLength(1); j++)
                    Console.Write($"{f[i, j],3}");
                Console.WriteLine();
            }
        }
    }
}
0
0 / 0 / 0
Регистрация: 11.11.2021
Сообщений: 20
26.04.2023, 02:56
Цитата Сообщение от Doomov Посмотреть сообщение
с 15 строки я сделал бы так...
ну я просто соблюдаю правило однозадачности, такой код легче читается
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.04.2023, 02:56
Помогаю со студенческими работами здесь

Минимальный по модулю элемент матрицы переместить в правый нижний угол
Дана квадратная матрица порядка n. С помощью допустимых преобразований добиться того,чтобы один из элементов матрицы обладающий одним из...

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

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

Путем перестановки строк и столбцов переместить минимальный элемент матрицы в левый нижний угол
Нужно для экзамена Путем перестановки строк и столбцов переместить минимальный элемент массива F(M, M) в левый нижний угол. f(x, y) =...

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


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru