2 / 3 / 0
Регистрация: 09.03.2020
Сообщений: 184
1

Расположить строки матрицы в соответствии с падением характеристик

14.06.2021, 11:36. Показов 355. Ответов 3
Метки с++ (Все метки)

Задача: Дано прямоугольную матрицу.
Характеристикой строки матрицы назовем сумму ее отрицательных элементов. Переставляя строки заданной матрицы, располагать их в соответствии с падения характеристик. Помогите!! (Шаблоны функций)
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
14.06.2021, 11:36
Ответы с готовыми решениями:

Переставляя строки матрицы расположить их в соответствии с убыванием характеристик
Характеристикой строки целочисленной матрицы назовем сумму ее положительных четных элементов....

Переставляя строки матрицы расположить их в соответствии с убыванием характеристик
Всем Привет! Помогите пожалуйста написать простенькую программу без сильно замороченного кода на...

Представляя строки матрицы, расположить их в соответствии с убыванием характеристик
Дана целочисленная прямоугольная матрица.Определите номер первого из столбцов,содержащих хотя бы 1...

Представляя строки матрицы, расположить их в соответствии с убыванием характеристик
Суть задания такая. Дана целочисленная прямоугольная матрица.Определите номер первого из...

3
427 / 310 / 129
Регистрация: 09.02.2021
Сообщений: 1,094
Записей в блоге: 1
14.06.2021, 14:51 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
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
#include <cstdlib>
#include <ctime>
#include <iostream>
using namespace std;
void Swap(int& a, int& b);
int SumOfNegEven(const int* arr, const int size);
void Sort(int** arr, const int M, const int N);
void Print(int** arr, const int M, const int N);
int main()
{
    srand(time(NULL));
    int M, N;
    cout << "Input m and n:" << endl;
    cin >> M >> N;
    int** arr = new int* [M];
    for (int i = 0; i < M; i++)
    {
        arr[i] = new int[N];
        for (int j = 0; j < N; j++) {
            arr[i][j] = -10 + rand() % 21;
        }
    }
 
    cout << "Before:" << endl;
    Print(arr, M, N);
    Sort(arr, M, N);
    cout << endl << "After:" << endl;
    Print(arr, M, N);
 
    for (int i = 0; i < M; i++)
        delete[] arr[i];
    delete[] arr;
    system("pause>nul");
    return 0;
}
void Swap(int& a, int& b)
{
    int tmp = a;
    a = b;
    b = tmp;
}
 
int SumOfNegEven(const int* arr, const int size)
{
    int sum = 0;
    for (int i = 0; i < size; i++)
        if (arr[i] < 0)
            sum += arr[i];
    return sum;
}
 
void Sort(int** arr, const int M, const int N)
{
    int* tmp = new int[M];
    for (int i = 0; i < M; i++)
        tmp[i] = SumOfNegEven(arr[i], N);
    for (int i = 0; i < M; i++)
        for (int j = M - 1; j > i; j--)
            if (tmp[j] > tmp[i])
            {
                Swap(tmp[i], tmp[j]);
                for (int k = 0; k < N; k++)
                    Swap(arr[i][k], arr[j][k]);
            }
 
    delete[] tmp;
}
 
void Print(int** arr, const int M, const int N)
{
    for (int i = 0; i < M; i++)
    {
        for (int j = 0; j < N; j++) {
            cout << arr[i][j] << " ";
        }
        cout << endl;
    }
}
0
2 / 3 / 0
Регистрация: 09.03.2020
Сообщений: 184
15.06.2021, 03:50  [ТС] 3
matviiv, Спасибо конечно но могли бы сделать через шаблони функций?
0
427 / 310 / 129
Регистрация: 09.02.2021
Сообщений: 1,094
Записей в блоге: 1
15.06.2021, 11:15 4
hacker2001,
Вроде так,чесно хз,уже давно не использивал
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
86
87
#include <cstdlib>
#include <ctime>
#include <iostream>
using namespace std;
 
template <typename T>
void Swap(T& a, T& b);
 
template <typename T>
T SumOfNegEven(const T* arr, const T size);
 
template <typename T>
void Sort(T** arr, const T M, const T N);
 
template <typename T>
void Print(T** arr, const T M, const T N);
int main()
{
    srand(time(NULL));
    int M, N;
    cout << "Input m and n:" << endl;
    cin >> M >> N;
    int** arr = new int* [M];
    for (int i = 0; i < M; i++)
    {
        arr[i] = new int[N];
        for (int j = 0; j < N; j++) {
            arr[i][j] = -10 + rand() % 21;
        }
    }
 
    cout << "Before:" << endl;
    Print(arr, M, N);
    Sort(arr, M, N);
    cout << endl << "After:" << endl;
    Print(arr, M, N);
 
    for (int i = 0; i < M; i++)
        delete[] arr[i];
    delete[] arr;
    system("pause>nul");
    return 0;
}
template <typename T>
void Swap(T& a, T& b)
{
    int tmp = a;
    a = b;
    b = tmp;
}
template <typename T>
T SumOfNegEven(const T* arr, const T size)
{
    int sum = 0;
    for (int i = 0; i < size; i++)
        if (arr[i] < 0)
            sum += arr[i];
    return sum;
}
template <typename T>
void Sort(T** arr, const T M, const T N)
{
    int* tmp = new int[M];
    for (int i = 0; i < M; i++)
        tmp[i] = SumOfNegEven(arr[i], N);
    for (int i = 0; i < M; i++)
        for (int j = M - 1; j > i; j--)
            if (tmp[j] > tmp[i])
            {
                Swap(tmp[i], tmp[j]);
                for (int k = 0; k < N; k++)
                    Swap(arr[i][k], arr[j][k]);
            }
 
    delete[] tmp;
}
template <typename T>
void Print(T** arr, const T M, const T N)
{
    for (int i = 0; i < M; i++)
    {
        for (int j = 0; j < N; j++) {
            cout << arr[i][j] << " ";
        }
        cout << endl;
    }
}
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
15.06.2021, 11:15
Помогаю со студенческими работами здесь

Переставляя строки заданной матрицы, расположить их в соответствии с ростом характеристик
Характеристикой строки целочисленной матрицы назовем сумму ее положительных четных элементов....

Переставляя строки заданной матрицы, расположить их в соответствии с убыванием характеристик
Дана целочисленная прямоугольная матрица. Характеристикой строки матрицы назовем сумму ее...

Переставляя строки заданной матрицы, расположить их в соответствии с ростом характеристик
помогите вот задача вот пример надо доделать как в задаче написано....надо суммировать все...

Переставляя строки заданной матрицы, расположить их в соответствии с ростом характеристик
Подскажите, пожалуйста, что делаю не так? //Характеристикой строки целочисленный матрицы назовем...

Переставляя строки заданной матрицы, расположить их в соответствии с ростом характеристик
Задание: Вариант 2 Дана целочисленная прямоугольная матрица. Переставляя строки заданной...

Переставляя строки заданной матрицы, расположить их соответствии с ростом характеристик.
помогите пожалуйста, очень надо. Переставляя строки заданной матрицы, расположить их соответствии...


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

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

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