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

Поменять местами максимальные элементы матриц

24.02.2015, 11:25. Показов 1715. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
кто может помочь решить лабораторную
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.02.2015, 11:25
Ответы с готовыми решениями:

Поменять местами максимальные элементы матриц
Ув. формчани, помогите решить задачку такого сорта. Поменять местами максимальные элементы матриц А (5 х 6) и B (3 х 5). Поиск...

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

поменять местами максимальные и минимальные значения
Необходимо поменять местами максимальные и минимальные значения в каждом столбце и строке в приведенном ниже массиве. int m=new int; ...

7
25.02.2015, 13:02
 Комментарий модератора 
Задание должно быть опубликовано в посте обычным текстом
0
38 / 38 / 30
Регистрация: 07.04.2014
Сообщений: 219
25.02.2015, 18:43
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
89
90
91
92
93
94
95
96
            const int size = 5;
            int [,] ar1 = new int[size, size];
            int[,] ar2 = new int[size, size];
            int max1 = 0;
            int max2 = 0;            
 
            Random rand = new Random();
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                    ar1[i, j] = rand.Next(0, 49);
                    ar2[i, j] = rand.Next(50, 100);
                }
            }
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                    Console.Write("{0}\t", ar1[i, j]);                  
                }
 
                Console.WriteLine();
            }
 
            Console.WriteLine();
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                   Console.Write("{0}\t", ar2[i, j]);                    
                }
 
                Console.WriteLine();
            }
 
            Console.WriteLine();
            
            // находим макс эл-ты в 1 и во 2 матрицах
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                    if (ar1[i, j] > max1)
                        max1 = ar1[i, j];
 
                    if (ar2[i, j] > max2)
                        max2 = ar2[i, j];
                }
            }            
 
            Console.WriteLine("max1 = " + max1);
            Console.WriteLine("max2 = " + max2);
            Console.WriteLine();
 
            // меняем максим значения в матрицах
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {                    
                    if (ar1[i, j] == max1)
                    {
                        ar1[i, j] = max2;
                    }
 
                    if (ar2[i, j] == max2)
                    {
                        ar2[i, j] = max1;
                    }                    
                }
            }          
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {                    
                    Console.Write("{0}\t", ar1[i, j]);                    
                }
 
                Console.WriteLine();
            }
 
            Console.WriteLine();
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {                   
                    Console.Write("{0}\t", ar2[i, j]);                    
                }
 
                Console.WriteLine();
            }
0
18 / 18 / 9
Регистрация: 21.02.2015
Сообщений: 81
25.02.2015, 18:56
Spiderman5,
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// меняем максим значения в матрицах
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {                    
                    if (ar1[i, j] == max1)
                    {
                        ar1[i, j] = max2;
                    }
 
                    if (ar2[i, j] == max2)
                    {
                        ar2[i, j] = max1;
                    }                    
                }
            }
зачем лишний раз в эти циклы влезать? Запоминать нужно не макс элемент, а i, j этого элемента
0
38 / 38 / 30
Регистрация: 07.04.2014
Сообщений: 219
25.02.2015, 18:59
Исправь мой вариант, пожалуйста, так, как будет лучше.
0
18 / 18 / 9
Регистрация: 21.02.2015
Сообщений: 81
25.02.2015, 19:16
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
89
90
91
92
93
94
95
96
        private static void Main(string[] args)
        {
 
            const int size = 5;
            int[,] ar1 = new int[size, size];
            int[,] ar2 = new int[size, size];
 
 
            Random rand = new Random();
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                    ar1[i, j] = rand.Next(0, 49);
                    ar2[i, j] = rand.Next(50, 100);
                }
            }
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                    Console.Write("{0}\t", ar1[i, j]);
                }
 
                Console.WriteLine();
            }
 
            Console.WriteLine();
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                    Console.Write("{0}\t", ar2[i, j]);
                }
 
                Console.WriteLine();
            }
 
            Console.WriteLine();
            int max1 = ar1[0,0];
            int max2 = ar2[0,0];
            int i1=0, i2=0, j1=0, j2=0;
            // находим макс эл-ты в 1 и во 2 матрицах
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                    if (ar1[i, j] > max1)
                    {
                        i1 = i;
                        j1 = j;
                        max1 = ar1[i, j];
                    }
 
                    if (ar2[i, j] > max2)
                    {
                        max2 = ar2[i, j];
                        i2 = i;
                        j2 = j;
                    }
                }
            }
 
            Console.WriteLine("max1 = " + max1);
            Console.WriteLine("max2 = " + max2);
            Console.WriteLine();
 
            // меняем максим значения в матрицах
            ar1[i1, j1] = max2;
            ar2[i2, j2] = max1;
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                    Console.Write("{0}\t", ar1[i, j]);
                }
 
                Console.WriteLine();
            }
 
            Console.WriteLine();
 
            for (int i = 0; i < size; i++)
            {
                for (int j = 0; j < size; j++)
                {
                    Console.Write("{0}\t", ar2[i, j]);
                }
 
                Console.WriteLine();
            }
            Console.ReadKey();
Если сильно захотеть от max1 и max2 можно избавиться.
0
38 / 38 / 30
Регистрация: 07.04.2014
Сообщений: 219
25.02.2015, 19:20
Да, красиво ! Благодарю за подсказку
0
871 / 721 / 304
Регистрация: 15.04.2013
Сообщений: 2,047
Записей в блоге: 5
26.02.2015, 02:27
Как вариант, поиск максимумов и их обмен
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
            var arr1 = ar1.Cast<int>().ToArray();
            var arr2 = ar2.Cast<int>().ToArray();
 
            int max1 = arr1.Max();
            int max2 = arr2.Max();
            
 
            Console.WriteLine("max1 = " + max1);
            Console.WriteLine("max2 = " + max2);
            Console.WriteLine();
 
            // меняем максим значения в матрицах
 
            int i1 = Array.IndexOf(arr1, max1);
            int i2 = Array.IndexOf(arr2, max2);
 
            ar1[i1 / size, i1 % size] = max2;
            ar2[i2 / size, i1 % size] = max1;
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.02.2015, 02:27
Помогаю со студенческими работами здесь

Поменять местами минимальные и максимальные елементы масива размера N
Дан масив целых чисел размера N. Вывести сначала все его парные (непарные) елементы, а потом- непарные (парные). Потом поменять местами...

В четных строках матрицы поменять местами максимальные и минимальные значения
Дана квадратная матрица порядка n. Преобразовать исходную матрицу по правилу: в четных строках поменять местами максимальные и минимальные...

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

Как в одномерном массиве поменять местами четные и нечетные элементы местами
Как в обычном одномерном массиве поменять местами четные и нечетные элементы местами, без array

Найти максимальные элементы в каждой строке массива и поменять им знаки на противоположные
мне нужно задачу было решить через подпрограммы.Найти максимальные элементы в каждой строке массива и поменять им знаки на...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru