Форум программистов, компьютерный форум, киберфорум
Java для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 17.09.2015
Сообщений: 27

В прямоугольном массиве NxM найдите все седловые элементы

04.05.2017, 12:59. Показов 970. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В прямоугольном массиве NxM найдите все седловые элементы(элемент массива называется седловым, если его значение является наименьшим в строке и наибольшем в столбце). Спасибо.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.05.2017, 12:59
Ответы с готовыми решениями:

В матрице NxM найти все седловые точки
Для матрицы размером NxM вывести на экран все седловые точки. (Элемент матрицы называется седловой, если он является наименьшим в своей...

В целочисленном прямоугольном массиве найти все элементы, соприкасающиеся углами с его минимальным элементом
В целочисленном прямоугольном массиве matrix найти все элементы, соприкасающиеся углами с его минимальным элементом. Входные данные...

Для матрицы размером NxM вывести на экран все седловые точки.
Для матрицы размером NxM вывести на экран все седловые точки. Элемент матрицы называется седловой точкой, если он является наименьшим в...

5
2884 / 2296 / 769
Регистрация: 12.05.2014
Сообщений: 7,978
04.05.2017, 14:44
Нашел. Пожалуйста.
0
 Аватар для Aviz__
2758 / 2065 / 509
Регистрация: 17.02.2014
Сообщений: 9,492
04.05.2017, 14:53
Дааа, забавно бы с минимальными затратами это сделать)).
0
 Аватар для Aviz__
2758 / 2065 / 509
Регистрация: 17.02.2014
Сообщений: 9,492
05.05.2017, 16:02
djohnny_z, поиграйся еще, может где и ошибка.
Java
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
97
98
99
100
101
102
103
104
105
public class CyberForum {
 
    public static void main(String[] args) {
        int [][] matr = {
                {4,3,3,5},
                {6,2,2,3},
                {2,3,1,3},
        };
 
        Matrixx extMatrN_M = new Matrixx(matr);
        System.out.println("Исходная матрица:");
        extMatrN_M.DisplayMatrix();
        System.out.println("Седловые елементы, если они есть, отмечены "*" :");
        extMatrN_M.DisplayMatrixSedlElements();
    }
}
//==========================
class Matrixx {
 
    private int [][] matrix;
    private int rows;
    private int cols;
    private boolean [][] sedlElements;
    private int minValuesInRows [];
    private int maxValuesInCols [];
 
 
    public Matrixx(int [][] externalMatrix) {
        this.matrix = externalMatrix;
        this.rows = externalMatrix.length;
        this.cols = externalMatrix[this.rows - 1].length;
        sedlElements = new boolean[this.rows] [this.cols];
        minValuesInRows = new int[this.rows];
        maxValuesInCols = new int[this.cols];
        searchCoordSedlElements();
    }
 
    private void getAllMinRow(){
        for (int i = 0; i < this.rows; i++) {
            minValuesInRows[i] = getMinValueRow(i);
        }
    }
 
    private void getAllMaxCols(){
        for (int i = 0; i < this.cols; i++) {
            maxValuesInCols[i] = getMaxValueCol(i);
        }
    }
 
    public void searchCoordSedlElements(){
        getAllMinRow();
        getAllMaxCols();
        for (int i = 0; i < this.rows; i++) {
            for (int j = 0; j < this.cols; j++) {
                if (minValuesInRows[i] == maxValuesInCols[j])
                    sedlElements[i][j] = true;
            }
        }
    }
 
    private int getMinValueRow(int row) {
        int min = this.matrix [row][0];
        if (this.cols == 1)
            return min;
 
        for (int i = 1; i < this.cols; i++) {
            if (this.matrix [row][i] < min)
                min = this.matrix [row][i];
        }
        return min;
    }
 
    private int getMaxValueCol(int col) {
        int max = this.matrix[0][col];
        if (this.rows == 1)
            return max;
 
        for (int i = 1; i < this.rows; i++) {
            if (this.matrix[i][col] > max)
                max = this.matrix[i][col];
        }
        return max;
    }
 
    public void DisplayMatrix() {
        for (int i = 0; i < this.rows; i++) {
            for (int j = 0; j < this.cols; j++) {
                System.out.printf("%4d", this.matrix[i][j]);
            }
            System.out.print("\n");
        }
    }
 
    public void DisplayMatrixSedlElements() {
        for (int i = 0; i < this.rows; i++) {
            for (int j = 0; j < this.cols; j++) {
                if (sedlElements[i][j])
                    System.out.printf("%4s", "*" + this.matrix[i][j]);
                else
                    System.out.printf("%4d",this.matrix[i][j]);
            }
            System.out.print("\n");
        }
    }
}
Результат работы
Исходная матрица:
4 3 3 5
6 2 2 3
2 3 1 3
Седловые елементы, если они есть, отмечены "*" :
4 *3 *3 5
6 2 2 3
2 3 1 3
0
528 / 263 / 70
Регистрация: 11.12.2016
Сообщений: 1,223
05.05.2017, 19:08
Aviz__,
Я пытался, но это оказалось дольше и сложнее чем я думал(с наскоку) и оставил.
Там наименьшее/наибольшее по условию, а значит только! одно на строку/столбец, и в примере вашей матрицы седловых точек нет.
То есть я добавлял такую штуку, ну и потом проверял.
Java
1
2
3
4
5
6
7
for (int i = 1; i < this.cols; i++) {
            if (this.matrix [row][i] < min) {
                min = this.matrix [row][i];
                isOne = true;                      }
            if (this.matrix [row][i] = min)
                isOne = false;
        }
0
 Аватар для Aviz__
2758 / 2065 / 509
Регистрация: 17.02.2014
Сообщений: 9,492
06.05.2017, 14:29
ViktorFX, может вы и правы)
Но, в строке 1, 2, 3, 1, 3 какой элемент наименьший и наибольший?))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.05.2017, 14:29
Помогаю со студенческими работами здесь

Для матрицы размером NxM вывести на экран все ее седловые точки
Для матрицы размером NxM вывести на экран все ее седловые точки. Элемент матрицы называется седловой точкой, если он является наименьшим в...

В целочисленном прямоугольном массиве matrixnm найти все элементы, соприкасающиеся углами с его максимальным элементом
помогите пожалуйста, сделал чтобы находил наибольший, но как крайние элементы найти понять не могу вот код=) program sashi_2; ...

Для матрицы размером NxM(N и M пользователь вводит вручную) вывести на экран все седловые точки
заранее спасибо!

В прямоугольном массиве найдите номера, у которых среднее арифметическое элементов меньше заданной величины
Программа запускается. Но при вводе массив просто отключается что не так? #include &lt;iostream&gt; #include &lt;conio.h&gt; using...

Для матрицы А размером NxM вывести на экран все ее седловые точки. Элемент матрицы называется седловой точкой,
Для матрицы А размером NxM вывести на экран все ее седловые точки. Элемент матрицы называется седловой точкой, если он является наименьшим...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 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. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru