Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 15, средняя оценка - 4.80
VovaMazur
-12 / 33 / 8
Регистрация: 10.03.2011
Сообщений: 133
#1

Седловая точка - C++

17.03.2011, 10:55. Просмотров 1998. Ответов 3
Метки нет (Все метки)

Элемент матрицы назовем седловой точки, если он является наименьшим в своей строке и одновременно крупнейшим в своем столбце или, наоборот, является крупнейшим в своей строке и наименьшим в своем столбце. Для заданной целой матрицы размером 10 × 15 напечатайте индексы всех ее седловых точек.
С++
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.03.2011, 10:55     Седловая точка
Посмотрите здесь:

Седловая точка - C++
Элемент матрицы назовем седловой точкой, если он является наименьшим в своей своей строке и одновременно наибольшим в своем столбце или,...

Седловая точка - C++
Дана целочисленная прямоугольная матрица.Определить номера строк и столбцов всех седловых точек матрицы #include <iostream.h> ...

Седловая точка - C++
Дана целочисленная прямоугольная матрица . Матрица А имеет седловую точку Аij, если Аij является минимальным элементом в i-ой строке и...

Массивы. Седловая точка - C++
элемент матрицы назовем седловой точкой,если он яв-ся наим.в своей строке и одновременно наиб.в своем столбце или наоборот яв-ся наиб.в...

Седловая точка в матрице - C++
Дана целочисленная прямоугольная матрица. Определить номера строк и столбцов всех седловых точек матрицы. (Седловая точка – элемент ...

удалить из каждой группы идущих подряд цифр, которой не предшествует точка, все начальные нули (кроме последнего, если за ним идет точка) - C++
В произвольном тексте, содержащем не более 10 строк, в каждой строке не более 80 символов, удалить из каждой группы идущих подряд цифр,...

Класс "Точка". Функция - определение в каком координатном угле находится точка - C++
1. Определить в глобальной области видимости функцию в соответствии с вариантом. Доступ к полям класса осуществить с помощью...

Точка входа - C++
Подскажите пожалуйста как найти точку входа приложения?

Точка в треугольнике - C++
Помогите! даны три вершины треугольника с координатами(коорд вводятся с клавиатуры) А(х1,y1) B(х2,y2) и С(х3,y3). И вводятся координаты...

Точка в Многоугольнике! - C++
Задача "Точка в многоугольнике". Условие. Многоугольник (выпуклый) задан координатами своих вершин (xi;yi), 1 i N в...

Точка останова - C++
Здравствуйте все! Не пойму в чём проблема. Вот так всё работает: void main() { char *c = new char ; delete c; }

Треугольник и точка - C++
Задача С клавиатуры вводится координаты вершин треугольника и координаты точки с .Определить лежит ли точка в треугольнике.И если можно...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
dxdy
97 / 97 / 5
Регистрация: 14.06.2010
Сообщений: 283
17.03.2011, 11:22     Седловая точка #2
И в чем у вас сложность при решении данной задачи?
IrineK
Заблокирован
17.03.2011, 15:22     Седловая точка #3
Решение для общего случая (до 100х100):
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
#include <iostream>
using namespace std;
 
int main()
{
 int i,j,n,m,found=0;
 float c[100][100], max[100][3], min[100][3];
 cout<<"razmer massiva"<<endl;
 cin>>n>>m;
 cout<<"vvedite matricy"<<endl;
 for (i=0;i<n;i++)
 {for (j=0;j<m;j++)
 cin>>c[i][j];
 }
  
for (i=0;i<n;i++)
{
        min[i][0]=c[i][0];
        min[i][1]=i;
        min[i][2]=0;
        for (j=1;j<m;j++)
                if(c[i][j]<min[i][0]) 
                {
                        min[i][0]=c[i][j];//сам минимум в i-ой строке
                        min[i][1]=i; //строка минимума
                        min[i][2]=j; //столбец минимума
                }
}
 
for (j=0;j<m;j++)
{
        max[j][0]=c[0][j];
        max[j][0]=0;
        max[j][0]=j;
        for (i=1;i<n;i++)
                if(c[i][j]>max[j][0]) 
                {
                        max[j][0]=c[i][j];// сам максимум в j-ом столбце
                        max[j][1]=i; //строка максимума
                        max[j][2]=j; //столбец максимума
                }
}
for (i=0;i<n;i++)
        for (j=0;j<m;j++)
                if(min[i][0]==max[j][0] && min[i][1]==max[j][1] && min[i][2]==max[j][2])
                {       cout<<"sedlovaya tozhka c["<<i<<"]["<<j<<"] = "<<c[i][j];
                found++;}
 
if(!found)
        cout<<"sedlovaya tozhka ne najdena\n";
 
return 0;
}
Fixer_84
493 / 340 / 163
Регистрация: 30.04.2016
Сообщений: 861
22.01.2017, 14:47     Седловая точка #4
VovaMazur, здравствуйте! Вот решение. Я его тестировал на различных ресурсах, таких как E-olymp и Дистанционная подготовка. В двух случаях из трех все тесты пройдены. Если кто-то найдет недочет в данной программе, прошу сообщить с примером матрицы для которой может быть найдена ошибка. Спасибо всем!

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
#include <iostream>
#include <climits>
 
using namespace std;
 
int main()
{
    int N, M, k;
    cout << "Введите размеры матрицы:" << endl;
    cout << "N = ";
    cin >> N;
    cout << "M = ";
    cin >> M;
    int* min = new int[N];
    int* max = new int[M];
    int** A = new int*[N];
    for (int i = 0; i < N; i++)
    {
        A[i] = new int[M];
    }
    cout << "Введите матрицу:" << endl;
    for (int i = 0; i < N; i++)
    {
        for (int j = 0; j < M; j++)
        {
            cin >> A[i][j];
        }
    }
    for (int i = 0; i < N; i++)
    {
        min[i] = INT_MAX;
        for (int j = 0; j < M; j++)
        {
            if (A[i][j] < min[i])
            {
                min[i] = A[i][j];
            }
        }
    }
    for (int j = 0; j < M; j++)
    {
        max[j] = INT_MIN;
        for (int i = 0; i < N; i++)
        {
            if (A[i][j] > max[j])
            {
                max[j] = A[i][j];
            }
        }
    }
    cout << "Индексы седловых точек:" << endl;
    k = 0;
    for (int i = 0; i < N; i++)
    {
        for (int j = 0; j < M; j++)
        {
            if (min[i] == max[j])
            {
                cout << i << " " << j << endl;
                k++;
            }
        }
    }
    if (!(k))
        cout << "Седловых точек нет!" << endl;
    for (int i = 0; i < N; i++)
    {
        delete[] A[i];
    }
    delete[] min;
    delete[] max;
    system("pause");
    return 0;
}
Yandex
Объявления
22.01.2017, 14:47     Седловая точка
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru