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

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

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

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

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

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

Точка с координатами C++
C++ оператор точка
Точка в треугольнике C++
C++ Седловая точка
удалить из каждой группы идущих подряд цифр, которой не предшествует точка, все начальные нули (кроме последнего, если за ним идет точка) C++
точка останова C++
C++ точка с координатами х,у. х<>0
C++ Точка в Многоугольнике!
C++ Седловая точка
Седловая точка C++
C++ Седловая точка в матрице
C++ Массивы. Седловая точка

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
dxdy
 Аватар для 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
478 / 325 / 156
Регистрация: 30.04.2016
Сообщений: 731
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     Седловая точка
Ответ Создать тему
Опции темы

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