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

В каждой строке матрицы выбирается элемент с наименьшим значением, затем среди этих чисел выбирается наибольшее - C++

Восстановить пароль Регистрация
 
tibeg
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 97
22.04.2014, 17:43     В каждой строке матрицы выбирается элемент с наименьшим значением, затем среди этих чисел выбирается наибольшее #1
Задание:
Кликните здесь для просмотра всего текста
. Дана действительная матрица размера mn, все элементы которой различны. В каждой строке выбирается элемент с наименьшим значением, затем среди этих чисел выбирается наибольшее. Указать индексы элемента с найденным значением.

Собственно не могу сообразить, как указать индекс найденного значения?
Код:
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
#include <iostream>
 
using namespace std;
 
int main()
{
    int a[3][3],i,j,mas[3],max;
 
 
    for(i=0;i<3;i++)
    {
        for(j=0;j<3;j++)
        {
            cout << "Vvedite [" << i+1 << "][" << j+1 << "] element:" ;
            cin  >> a[i][j];
            
        }
    }
 
 
    system("cls");
 
 
    for(i=0;i<3;i++)
    {
        for(j=0;j<3;j++)
        {
            cout << a[i][j] << "  ";
        }
 
        cout << "\n";
    }
 
 
 
    for(i=0;i<3;i++)
    {
        for(j=0;j<3;j++)
        {
            if(a[i][0] >= a[i][j])
            mas[i]=a[i][j];
        }
    }
 
    cout << "\n";
 
    for(i=0;i<3;i++)
    {
        cout << "Stroka " << i <<" = " <<mas[i] << "\n";
    }
 
    for(i=0;i<3;i++)
    {
        if(mas[0] < mas[i])
        {
        max    = mas[i];
        mas[i] = mas[0];
        mas[0] = max;
        }
    }
 
    cout << "\nMakcumalnoe znachenie:" << max << "\n";
 
}
Добавлено через 8 минут
Разобрался сам)
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
#include <iostream>
 
using namespace std;
 
int main()
{
    int a[3][3],i,j,mas[3],max,ind_i,ind_j;
 
 
    for(i=0;i<3;i++)
    {
        for(j=0;j<3;j++)
        {
            cout << "Vvedite [" << i+1 << "][" << j+1 << "] element:" ;
            cin  >> a[i][j];
            
        }
    }
 
 
    system("cls");
 
 
    for(i=0;i<3;i++)
    {
        for(j=0;j<3;j++)
        {
            cout << a[i][j] << "  ";
        }
 
        cout << "\n";
    }
 
 
 
    for(i=0;i<3;i++)
    {
        for(j=0;j<3;j++)
        {
            if(a[i][0] >= a[i][j])
            mas[i]=a[i][j];
        }
    }
 
    cout << "\n";
 
    for(i=0;i<3;i++)
    {
        cout << "Stroka " << i <<" = " <<mas[i] << "\n";
    }
 
    for(i=0;i<3;i++)
    {
        if(mas[0] < mas[i])
        {
        max    = mas[i];
        mas[i] = mas[0];
        mas[0] = max;
        }
    }
 
        for(i=0;i<3;i++)
        {
            for(j=0;j<3;j++)
            {
                if(a[i][j]==max)
                {
                    ind_i=i;
                    ind_j=j;
                }
            }
        }
        
        
        cout << "\nMakcumalnoe znachenie:" << max << "\n";
        cout << "Ego undeks i=" << ind_i <<" j=" << ind_j << "\n";
 
 
 
 
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.04.2014, 17:43     В каждой строке матрицы выбирается элемент с наименьшим значением, затем среди этих чисел выбирается наибольшее
Посмотрите здесь:

В каждой строке находится минимальный элемент,затем среди этих чисел выбирается максимальное.Напечатать индексы выбранного элемента C++
В двумерном массиве найти в каждой строке максимальный элемент, затем среди этих чисел выбрать минимальный C++
C++ Дана действительная матрица размером пхт, все элементы которой различны. В каждой строке выбирается элемент с наименьшим значением, затем среди этих ч
В каждой строке двумерного массива находится минимальный элемент, затем среди этих чисел находится максимальное. Напечатать индексы этого элемента. C++
В каждой строке выбирается элемент с наименьшим значением, затем среди этих чисел выбирается наибольшее C++
В каждой строке находится минимальной элемент, затем среди этих чисел выбирается максимальное C++
C++ В каждой строке найти минимальный элемент, затем среди них найти максимальное и вывести на экран индекс этого элемента
C++ В каждой строке матрицы найти элемент с минимальным значением и его номер столбца

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
nmcf
4265 / 3696 / 1243
Регистрация: 14.04.2014
Сообщений: 14,476
22.04.2014, 17:55     В каждой строке матрицы выбирается элемент с наименьшим значением, затем среди этих чисел выбирается наибольшее #2
Почему ты везде сравниваешь с первым элементом в строке?
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
int masj[3]; // номера столбцов с минимума для каждой строки
 
for(i=0;i<3;i++)
    {
        mas[i] = a[i][0];
        masj[i] = 0;
        for(j=1;j<3;j++)
        {
            if(mas[i] > a[i][j])
            {
                mas[i]=a[i][j];
                masj[i] = j;
            }
        }
    }
 
int maxi = 0;
max = mas[0];
for(i=1;i<3;i++)
    {
        if(max < mas[i])
        {
        max    = mas[i];
        maxi = i; 
        }
    }
max - максимум, maxi - индекс строки, masj[maxi] - индекс столбца
Yandex
Объявления
22.04.2014, 17:55     В каждой строке матрицы выбирается элемент с наименьшим значением, затем среди этих чисел выбирается наибольшее
Ответ Создать тему
Опции темы

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