-8 / 0 / 0
Регистрация: 17.01.2020
Сообщений: 46
1

Заменить элементы в двумерном массиве

17.01.2020, 17:13. Показов 258. Ответов 0
Метки нет (Все метки)

Заменить первый максимальный нечетный элемент в заштрихованной
области, включая границы, на первый минимальный четный элемент из
незаштрихованной области, не включая границы. Ноль не учитывать.
Если таких элементов нет, выдать сообщение о том, какого именно
элемента (четного или нечетного) нет в массиве.
Заштрихованная
области - это элементы находящиеся над главной диагональю.
граница - это главная диагональ.
Размер и элементы массива вводятся с КЛАВИАТУРЫ!!!!!!!!!!!!!
Пример:
Ввод:
4 5 8 2 1
2 4 1 3 2
4 3 7 2 0
9 5 2 7 4
4 6 8 1 3
Результат:
4 5 8 2 1
7 4 1 3 2
4 3 2 2 0
9 5 2 7 4
4 6 8 1 3

Добавлено через 1 час 39 минут
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
#include <stdlib.h>
#include <iostream>
#include <ctime>
#include <math.h>
 
using namespace std;
 
int main()
{   
    int n, i, j, max, min, q, w;
    cout <<" n = ";
    cin >> n;
    int **a = new int*[n];
    for(int i = 0; i < n; i++)
    a[i] = new int[n];
    for(int i = 0; i < n; i++, cout << endl)
    for(int j = 0; j < n; j++)
    {
        cout <<" a["<< i <<"]["<< j <<"]= ";
        cin>>a[i][j];
    }
    cout<<" Array: "<< endl;
    for(int i = 0; i < n; i++, cout << endl)
    for(int j = 0; j < n; j++)
    cout<<a[i][j]<<" ";
    for(int i = 0; i < n; i++)
 
 
    //search min
 
    min = a[1][1];
    for (i = 1; i < n; i++)
    {
        for (j = 0; j < i; j++)
        {
            if (a[i][j] < min && min % 2 == 1) min = a[i][j];
        }
    }
    //search max
    max = a[1][1];
    for (i = 0; i <= j; i++)
    {
        for (j = i; j < n; j++)
        {
            if (a[i][j] > max && max % 2 == 0) max = a[i][j];
        }
    }
    cout <<" MIN = " << min << endl <<" MAX = " << max << endl;
    //zamena
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            if (a[i][j] == min) a[i][j] = max;
        }
    }
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            if (a[i][j] == max) a[i][j] = min;
        }
    }
    //vivod
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            cout << a[i][j] << " ";
        }
        cout << endl;
    }
    cout << endl;
    system("pause");
    return 0;
}
Добавлено через 1 минуту
Или
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
#include <stdlib.h>
#include <iostream>
#include <ctime>
#include <math.h>
 
using namespace std;
 
int main()
{   
    int n, i, j, max, min, q, w;
    cout <<" n = ";
    cin >> n;
    int **a = new int*[n];
    for(int i = 0; i < n; i++)
    a[i] = new int[n];
    for(int i = 0; i < n; i++, cout << endl)
    for(int j = 0; j < n; j++)
    {
        cout <<" a["<< i <<"]["<< j <<"]= ";
        cin>>a[i][j];
    }
    cout<<" Array: "<< endl;
    for(int i = 0; i < n; i++, cout << endl)
    for(int j = 0; j < n; j++)
    cout<<a[i][j]<<" ";
    for(int i = 0; i < n; i++)
 
 
    //search min
 
    min = a[1][1];
    for (i = 1; i < n; i++)
    {
        for (j = 0; j < i; j++)
        {
            if (a[i][j] < min && min % 2 == 1) min = a[i][j];
        }
    }
    //search max
    max = a[1][1];
    for (i = 0; i <= j; i++)
    {
        for (j = i; j < n; j++)
        {
            if (a[i][j] > max && max % 2 == 0) max = a[i][j];
        }
    }
    cout <<" MIN = " << min << endl <<" MAX = " << max << endl;
    //zamena
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            if (a[i][j] == min) a[i][j] = max;
        }
    }
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            if (a[i][j] == max) a[i][j] = min;
        }
    }
    //vivod
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            cout << a[i][j] << " ";
        }
        cout << endl;
    }
    cout << endl;
    system("pause");
    return 0;
}
Добавлено через 1 минуту
Ну или так
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
#include <stdlib.h>
#include <iostream>
#include <ctime>
 
using namespace std;
 
int main()
{   
    int n, i, j, max, min, q, w;
    cout <<" n = ";
    cin >> n;
    int **a = new int*[n];
    for(int i = 0; i < n; i++)
    a[i] = new int[n];
    for(int i = 0; i < n; i++, cout << endl)
    for(int j = 0; j < n; j++)
    {
        cout <<" a["<< i <<"]["<< j <<"]= ";
        cin>>a[i][j];
    }
    cout<<" Array: "<< endl;
    for(int i = 0; i < n; i++, cout << endl)
    for(int j = 0; j < n; j++)
    cout<<a[i][j]<<" ";
    for(int i = 0; i < n; i++)
        //search min
 
    min = a[1][1];
    for (i = 1; i < n; i++)
    {
        for (j = 0; j < i; j++)
        {
            if (a[i][j] < min && min % 2 == 1) min = a[i][j];
        }
    }
    //search max
    max = a[1][1];
    for (i = 0; i < n; i++)
    {
        for (j = i; j < n; j++)
        {
            if (a[i][j] > max && max % 2 == 0) max = a[i][j];
        }
    }
    cout << "MIN: " << min << endl << "MAX: " << max << endl;
    //zamena
    int j1, i1;
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            if (a[i][j] == min)
            {
                a[i][j] = max;
                j1 = j;
                i1 = i;
            }
        }
    }
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            if (a[i][j] == max && i != i1 && j != j1) a[i][j] = min;
        }
    }
    //vivod
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            cout << a[i][j] << " ";
        }
        cout << endl;
    }
    cout << endl;
    system("pause");
    return 0;
}
__________________
Помощь в написании контрольных, курсовых и дипломных работ здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.01.2020, 17:13
Ответы с готовыми решениями:

Заменить элементы в двумерном массиве
Заменить первый максимальный нечетный элемент в заштрихованной области, включая границы, на первый...

В двумерном массиве 5x7 заменить все элементы на 0
#include&lt;iostream&gt; #include&lt;stdlib.h&gt; #include&lt;time.h&gt; #include &lt;Windows.h&gt; using namespace...

В динамическом двумерном массиве заменить на 0 элементы с n-го по m-ный
Как можно в динамическом двумерном массиве заменить на 0 и вывести на экран элементы с n-го по...

Найти в двумерном массиве минимальные элементы и заменить их нулями
#include &lt;iostream&gt; #include &lt;cstdlib&gt; #include &lt;ctime&gt; using namespace std; int main() {...

0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.01.2020, 17:13

В двумерном числовом массиве все отрицательное элементы заменить нулями
в двумерном числовом массиве все отрицательное элементы заменить нулями!

В двумерном массиве заменить все элементы, кратные 3, на 1 и найти их количество
В двумерном массиве В(7,8) заменить все элементы кратные 3 на 1 и найти их количество пожалуйста!!!

В двумерном массиве заменить все четные элементы на минимальный элемент матрицы
Задание: В двумерном массиве заменить все четные элементы на минимальный элемент матрицы. Зарание...

В двумерном массиве заменить элементы строк с четными индексами элементами строк с нечетными индексами
Дан массив чисел, А (5, 4). Превратить массив , заменив элементы строк с четными индексами...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru