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

Минимакс и максимин - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 20, средняя оценка - 4.75
trtua
0 / 0 / 0
Регистрация: 20.11.2010
Сообщений: 4
20.11.2010, 20:36     Минимакс и максимин #1
Задана матрица размером m*n.
Найти элемент, образующий минимакс(минимаксным значением называется максимум среди построчных минимумов).
Найти элемент матрицы, образующий максимин(максимин - минимум среди полстолбцовых максимумов)

Понимаю алгоритм, но не знаю как написать, помогите пожалуйста.
Надо найти максимальный среди минимальных элементов её строк и вывести его на экран.
Как я понял, необходимо найти сначала минимумы строк - заполнить ими массив.
И потом в этом массиве найти максимум. и вывести его на экран.
соотв. и с максимином.

Напишите пожалуйста программу.
Спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.11.2010, 20:36     Минимакс и максимин
Посмотрите здесь:

Алгоритм Минимакс C++
Каков вообще минимакс косинуса угла между трёхмерным вектором и координатыми осями?
Крестики-нолики 3х3 и 5х5 МиниМакс C++
Минимакс

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
VASSUV
MiThEoN
 Аватар для VASSUV
412 / 278 / 15
Регистрация: 31.10.2009
Сообщений: 403
Записей в блоге: 2
20.11.2010, 20:44     Минимакс и максимин #2
не обязательно создавать новый массив! только две переmенные max и min
Добавлено через 12345678901234567890123456789 минуты
C++
1
2
3
4
5
6
7
8
9
10
11
12
int max=a[0][0],min;
for(int i = 0; i < n; i++)
{
   min=a[i][0];
   for(int j = 1; j < m; j++)
   {
       if(a[i][j]<min)
         min=a[i][j];
   }
   if(max<min)
      max=min;
}
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
20.11.2010, 23:28     Минимакс и максимин #3
VASSUV, Неправильный алгоритм. Например a[0][0] окажется самым большим в массиве. Его значение и выведет программа в качестве результата.
VASSUV
MiThEoN
 Аватар для VASSUV
412 / 278 / 15
Регистрация: 31.10.2009
Сообщений: 403
Записей в блоге: 2
20.11.2010, 23:32     Минимакс и максимин #4
Цитата Сообщение от valeriikozlov Посмотреть сообщение
Неправильный алгоритм. Например a[0][0] окажется самым большим в массиве. Его значение и выведет программа в качестве результата
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
int max,min;
for(int i = 0; i < n; i++)
{
   min=a[i][0];
   for(int j = 1; j < m; j++)
   {
       if(a[i][j]<min)
         min=a[i][j];
   }
   if(i==0)
      max=min;
   if(max<min)
      max=min;
}
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
20.11.2010, 23:33     Минимакс и максимин #5
VASSUV,
C++
1
2
if(i=0)
      max=min;
не-а. == должно быть
VASSUV
MiThEoN
 Аватар для VASSUV
412 / 278 / 15
Регистрация: 31.10.2009
Сообщений: 403
Записей в блоге: 2
20.11.2010, 23:34     Минимакс и максимин #6
торопился и недописал!
trtua
0 / 0 / 0
Регистрация: 20.11.2010
Сообщений: 4
25.12.2010, 19:33  [ТС]     Минимакс и максимин #7
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
//---------------------------------------------------------------------------
#include <iostream.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
int main(int argc, char* argv[])
{
const int n=3;
int a[n];
for (int i=0; i<n; i++)
cin >> a[i];
for (int j=0; j<n; j++)
cin >> a[j];
 
int max ,min;
for(int i = 0; i < n; i++)
{
   min=a[i][0];
   for(int j = 1; j < m; j++)
   {
       if(a[i][j]<min)
         min=a[i][j];
   }
   if(i==0)
      max=min;
      cout<<max;
   if(max<min)
      max=min;
      cout<<max;
}
int z;
cin >>z;
return 0;
}
//---------------------------------------------------------------------------
на 20 строке выбивает ошибку - invalid direction, подскажите, что исправить?
MILAN
 Аватар для MILAN
883 / 777 / 86
Регистрация: 21.02.2009
Сообщений: 1,722
25.12.2010, 19:38     Минимакс и максимин #8
Цитата Сообщение от trtua Посмотреть сообщение
int a[n];
C++
1
int a[n][n];
Добавлено через 1 минуту
Цитата Сообщение от trtua Посмотреть сообщение
for (int i=0; i<n; i++)
cin >> a[i];
for (int j=0; j<n; j++)
cin >> a[j];
C++
1
2
3
for (int i=0; i<n; i++)
for (int j=0; j<n; j++)
cin >> a[i][j];
Yandex
Объявления
25.12.2010, 19:38     Минимакс и максимин
Ответ Создать тему
Опции темы

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