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

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

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

Переделать поиск максимального элемента матрицы через указатели - C++

09.03.2017, 16:44. Просмотров 79. Ответов 1
Метки нет (Все метки)

3)Задана матрица D(4,4). Определить максимальный среди положительных, минимальный среди отрицательных и поменять их местами
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
#include <iostream>
#include <stdlib.h>
using namespace std;
 
int main()
{
    int a[4][4], max, min, imax, jmax, imin, jmin;
    int n = 4;
    for (int i = 0; i < n; i++)
    {
        for(int j = 0; j < n; j++)
        {
            cin >> a[i][j];
        }
    }
    max = 0;
    min = 0;
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            if (a[i][j] > 0)
            {
                if (a[i][j] > max)
                {
                    max = a[i][j];
                    imax = i;
                    jmax = j;
 
                }
            }
            else
            {
                if (a[i][j] < min)
                {
                    min = a[i][j];
                    imin = i;
                    jmin = j;
                }
            }
        }
    }
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            a[imin][jmin] = max;
            a[imax][jmax] = min;
        }
    }
 
 
    cout << endl;
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            cout << a[i][j] << " ";
        }
        cout << endl;
    }
    cout<< endl << max << " " << imax << " " << jmax << endl;
    cout << min << " " << imin << " " << jmin << endl;
    system("pause");
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.03.2017, 16:44
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Переделать поиск максимального элемента матрицы через указатели (C++):

Поиск максимального элемента строки матрицы (функции) - C++
Здравствуйте! Помогите пожалуйста с задачкой: сделать программу в функции которой будет высчитываться произведение максимальных эле¬ментов...

Поиск максимального элемента матрицы и перестановка ее строк - C++
написать код который создает массив, ищет максимальный элемент в строке первого столбца и переставляет строку на первое место, после этого...

Поиск индекса и значения максимального элемента в массиве через ссылку - C++
Здравствуйте, помогите, пожалуйста: Программа запрашивает у пользователя размер массива, выделяет память из кучи и заполняет числами от 0...

программа сделана через указатели, переделать через ссылки. - C++
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;iomanip&gt; #include &lt;cmath&gt; using namespace std; void calculation(double...

Как переделать через указатели? - C++
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;math.h&gt; using namespace std; int main() { float u,v,n,h,x,y; cout &lt;&lt;&quot;...

переделать программу через указатели - C++
очень нужна ваша помощь #include&lt;math.h&gt; #include&lt;stdio.h&gt; #include &lt;conio.h&gt; void main () {int x,a; float y; ...

1
MrGluck
Модератор
Эксперт CЭксперт С++
7521 / 4659 / 703
Регистрация: 29.11.2010
Сообщений: 12,715
23.03.2017, 18:22 #2
Вы, кстати, не учли, что 0 - беззнаковое число.

Добавлено через 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
38
39
40
41
#include <cstdlib>
#include <iostream>
using namespace std;
 
int main()
{
    const int n = 4;
    int a[n][n], *pMin = nullptr, *pMax = nullptr;
 
    for (int i = 0; i < n; i++)
        for (int j = 0; j < n; j++)
        {
            cin >> a[i][j];
            // если элемент больше нуля и pMax не установлен или меньше
            if (a[i][j] > 0 && (!pMax || a[i][j] > *pMax))
                pMax = &a[i][j];
            // иначе если элемент меньше нуля и pMin не установлен или больше
            else if (a[i][j] < 0 && (!pMin || a[i][j] < *pMin))
                pMin = &a[i][j];
        }
 
    // если указатели остались нулевыми (нет ни одного отрицательного или положительного элемента)
    if (!pMin || !pMax)
        cout << "No changes\n";
    else
    {
        // меняем местами содержимое
        int tmp = *pMin;
        *pMin = *pMax;
        *pMax = tmp;
    }
 
    // выводим результат
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
            cout << a[i][j] << " ";
        cout << endl;
    }
    system("pause");
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.03.2017, 18:22
Привет! Вот еще темы с ответами:

Помогите переделать работу с массивом через указатели - C++
помогите оформить через указатели...понимаю,что элементарно....но я трамвай for(j=k; j&lt;=N; j++) { ...

Нужно переделать проекты через указатели.Буду очень благодарен) - C++
Переделать всё через указатели. №1 Удалить элементы кратные 7. Добавить после каждого нечетного элемента массива элемент со значением...

Одномерные массивы и указатели (Все отрицательные элементы увеличить на значение максимального элемента. Осуществить сдвиг) - C++
Дан массив A. Все отрицательные элементы увеличить на значение максимального элемента. Осуществить сдвиг влево на k позиций, где k – число...

Перестановка в каждой строке матрицы максимального элемента и элемента главной диагонали - C++
Сформировать из двухмерного массива другой, поменяв местами (построчно) максимальные элементы и элементы главной диагонали.


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

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