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

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

24.04.2023, 18:33. Показов 728. Ответов 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
3257 / 3275 / 556
Регистрация: 17.02.2019
Сообщений: 5,184
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
3257 / 3275 / 556
Регистрация: 17.02.2019
Сообщений: 5,184
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
Ответ Создать тему
Новые блоги и статьи
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 На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru