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

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

Войти
Регистрация
Восстановить пароль
 
kira_1
0 / 0 / 0
Регистрация: 16.11.2013
Сообщений: 59
#1

Найти седловую точку в матрице. Использование функций - C++

18.05.2014, 23:14. Просмотров 240. Ответов 7
Метки нет (Все метки)

Элемент матрицы является седловой точкой, если он является наименьшим в своей строке и наибольшим в своем столбце (или наоборот: наибольшим в своей строке и наименьшим в своем столбце).Для заданной матрицы определить все седловые точки.

Подскажите, пожалуйста, как вызвать функции, чтобы они передавали свое значение в main и программа правильно работала. Вот код:

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
#include <cstdlib>
#include <iostream>
#include <stdio.h>
const int  MAX_WIDTH=5;
const int  MAX_HEIGHT=8;
int max_h1,min_w1,max_w2,min_h2;
void Max1(int);
void Min1(int);
void Max2(int);
void Min2(int);
 
#include <stdlib.h>
using namespace std; 
int m[MAX_WIDTH][MAX_HEIGHT]= {
    { 7, 2, 1, 3, 2, 2, 7, 2 },
    { 7, 3, 2, 1, 1, 2, 7, 2 },
    { 7, 4, 2, 2, 2, 3, 7, 3 },
    { 7, 7, 5, 7, 7, 7, 9, 7 },
    { 6, 2, 3, 3, 5, 1, 4, 3 },
};
int i, j, val,found=0;
int min_h2[MAX_WIDTH], max_w2[MAX_HEIGHT];
 
int main()
{   
 
for ( i= 0; i<MAX_WIDTH; i++ ) {
    for ( j= 0; j<MAX_HEIGHT; j++ ) {
    
        if (( m[i][j] == min_w1[j] && m[i][j] == max_h1[i] )|| ( m[i][j] == max_w2[j] && m[i][j] == min_h2[i] )) {
            cout <<"m["<<i<<"]["<<j<<"]=" << m[i][j] << endl;
            found++;
        }
       
    }
    
}
if(!found)
    printf("0");
system("pause");
return 0;
}
 
void Max1(int m[MAX_WIDTH][MAX_HEIGHT],int max_h1[MAX_WIDTH])
{
int val;
for ( i= 0; i<MAX_WIDTH; i++ ) 
   { val= m[i][0];
    for ( j= 1; j<MAX_HEIGHT; j++ ) {
        if ( m[i][j]>val ) { val= m[i][j]; }
    }
    max_h1[i]= val;
    
}}
 
 
 int Min1(int m[MAX_WIDTH][MAX_HEIGHT],int min_w1[MAX_HEIGHT])
{
for ( j= 0; j<MAX_HEIGHT; j++ ) {
    val= m[0][j];
    for ( i= 1; i<MAX_WIDTH; i++ ) {
        if ( m[i][j]<val ) { val= m[i][j]; }
    }
    min_w1[j]= val;
}}
void Max2(int m[MAX_WIDTH][MAX_HEIGHT],int max_h[MAX_WIDTH])
{
int val;
for ( i= 0; i<MAX_WIDTH; i++ ) 
   { val= m[i][0];
    for ( j= 1; j<MAX_HEIGHT; j++ ) {
        if ( m[i][j]<val ) { val= m[i][j]; }
    }
    min_h2[i]= val;
}}
 
 void Min2(int m[MAX_WIDTH][MAX_HEIGHT],int max_h[MAX_HEIGHT])
{
for ( j= 0; j<MAX_HEIGHT; j++ ) {
    val= m[0][j];
    for ( i= 1; i<MAX_WIDTH; i++ ) {
        if ( m[i][j]>val ) { val= m[i][j]; }
    }
    max_w2[j]= val;
}}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.05.2014, 23:14
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти седловую точку в матрице. Использование функций (C++):

Найти седловую точку матрицы! - C++
Седловой точкой матрицы назовём такой элемент, который является одновременно максимальным в столбце и минимальным в строке. Найти одну,...

Код неправильно определяет седловую точку - C++
#include &quot;stdafx.h&quot; #include &lt;ctime&gt; #include &lt;cstdlib&gt; #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;stdio.h&gt; using...

Найти седловую точку целочисленной матрицы с числом строк не более 12, числом столбцов не более 20 (ООП) - C++
1. Найти седловую точку целочисленной матрицы с числом строк не более 12, числом столбцов не более 20. Найти произведение ненулевых...

Множественное наследование, Перегрузка функций, Перегрузка операторов, Использование дружественных функций и классов, Использование шаблонов классов - C++
Здравствуйте!!! Я бы хотел попросить помоч решить...ну или скинуть примеры таких задач, если вдруг у вас они завалялись на компе или...

Итерационные циклы,Определение и вызов функций,Использование библиотечных функций stdio.h - C++
Помогите решить задания: 1.Дано натуральное число n. Найти разность между первой цифрой этого числа и суммой всех остальных. ...

Использование стандартных функций (найти все корни уравнения на заданном интервале [a;b] с заданной точностью) - C++
Необходимо создать программу, которая находит все корни уравнения на заданном интервале с заданной точностью (задается пользователем)....

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
S_el
2100 / 1611 / 308
Регистрация: 15.12.2013
Сообщений: 6,451
18.05.2014, 23:19 #2
kira_1, аргументы передавайте по ссылке.
0
kira_1
0 / 0 / 0
Регистрация: 16.11.2013
Сообщений: 59
18.05.2014, 23:21  [ТС] #3
Напишите, пожалуйста, пример как это делать.
0
S_el
2100 / 1611 / 308
Регистрация: 15.12.2013
Сообщений: 6,451
18.05.2014, 23:30 #4
kira_1, пример:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
using namespace std;
 
void my_func(int &var);
 
int main() {
    int t=0;
    cout<<"do "<<t<<endl;
    my_func(t);
    cout<<"posle "<<t<<endl;
    return 0;
}
 
void my_func(int &var)
{
    var++;
}
0
kira_1
0 / 0 / 0
Регистрация: 16.11.2013
Сообщений: 59
18.05.2014, 23:38  [ТС] #5
А как передавать значения с массива?
0
S_el
2100 / 1611 / 308
Регистрация: 15.12.2013
Сообщений: 6,451
18.05.2014, 23:39 #6
kira_1, либо передавайте весь массив целиком,либо элемент отдельно.
0
kira_1
0 / 0 / 0
Регистрация: 16.11.2013
Сообщений: 59
18.05.2014, 23:41  [ТС] #7
Если можно, покажите, пожалуйста, на моем примере, как в main вызвать функцию void Max1
0
S_el
2100 / 1611 / 308
Регистрация: 15.12.2013
Сообщений: 6,451
18.05.2014, 23:47 #8
kira_1, для лучшего понимания я бы посоветовал на основании кода из 1 сообщения,написать программу самостоятельно,избавившись от ненужных библиотек и глобальных переменных.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.05.2014, 23:47
Привет! Вот еще темы с ответами:

Работа с двумерными числовыми массивами. Использование указателей. Использование функций пользователя. - C++
Помогите пожалуйста!!!!!!! Сделать три варианта: первый вариант – передача данных между функциями с помощью глобального...

Найти точку D, симметричную точку A относительно стороны BC. - C++
помогите решить пожалуйста...

Использование функций и шаблонов функций - C++
Люди помогите пожалуйста буду очень благодарна) вобщем вот первая часть лабы Написать программу, функция main которой включает...

Использование функций и шаблонов функций - C++
Составьте программу – формирование цены на молоко. Животновод в начале каждой зимы цену на молоко на р%, а каждым летом снижает на столько...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
18.05.2014, 23:47
Ответ Создать тему
Опции темы

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