Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
1

Работа с динамическим двумерным массивом

18.11.2016, 16:46. Просмотров 986. Ответов 3

Написал код. В двумерном массиве 5х5 находится максимальное значение каждой строки и затем минимальное из них.
Необходимо указывать размеры массива с клавиатуры и все также заполнять его случайными числами, заданными с клавиатуры. Также нужно обернуть алгоритмы ввода, заполнения массива, нахождения максимума и минимума в функции.
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
// MinMaxMatrix.cpp : Defines the entry point for the console application.
//
 
#include "stdafx.h"
#include <iostream>
#include <locale>
#include <time.h>
#include <conio.h>
#include <iomanip>
 
using namespace std;
 
int assignment_arr() {
 
}
 
int filling_arr() {
 
}
int finding_max() {
 
}
int finding_min_in_max() {
 
}
 
int main()
{
    srand(unsigned(time(NULL)));
    int minn = 1;
    int wq;
    int a_min = 100000000;
 
    setlocale(LC_ALL, "RUS");
 
    const int i = 5; const int j = 5; const int size = 5;
    int arr[i][j], max[size] = { 0 }, num, ctr = 0;
 
    cout << "Исходный массив:" << endl;
 
    for (int q = 0; q<i; q++) {
        for (int w = 0; w<j; w++) {
            arr[q][w] = rand() % 100 + minn;
            cout << arr[q][w] << "\t";
        }
        cout << endl;
    }
 
    for (int q = 0; q<i; q++)
    {
        num = arr[q][0];
        for (int w = 1; w < j; w++)
        {
            if (num<arr[q][w]) {
                max[ctr] = arr[q][w];
                num = arr[q][w];
            }
            else
                max[ctr] = num;
        }
        ctr++;
    }
 
    cout << endl << "Максимальные элементы строк:\n";
    for (wq = 0; wq < size; wq++)
    {
        cout << max[wq] << "\t" << endl;
            
    }
 
    for (int i = 0; i<5; i++)
    {
        
        if (max[i] < a_min)
            a_min = max[i];
        
    }
    cout <<"Минимальный среди максимальных: " << a_min << endl;
 
    system("pause");
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
18.11.2016, 16:46
Ответы с готовыми решениями:

Утечка памяти в задаче с двумерным динамическим массивом
Matrix::Matrix(int n,int m) // конструктор с параметрами { N=n; M=m; // объявление...

Ошибка с памятью при работе с динамическим двумерным массивом
Вроде всё правильно, но в ходе работы программа выдаёт ошибку(на скрине). Дело в двумерном...

Создать класс для работы с двумерным динамическим массивом чисел
Создать класс для работы с двумерным динамическим массивом чисел. Методы: -заполнить массив...

Написать программу для работы с динамическим целочисленным двумерным массивом
Написать программу для работы с динамическим целочисленным двумерным массивом. Количество строк,...

3
Модератор
Эксперт С++
10254 / 8573 / 5197
Регистрация: 18.12.2011
Сообщений: 22,938
18.11.2016, 17:24 2
Большая часть есть в шаблоне
Образцы (шаблоны) программ для типовых задач
Останется дописать функции нахождения максимума и минимума в функции
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
//
// пример обработки матрицы - нахождение максимума
//
int Process( int ** M, size_t n, size_t m ) {
    int Max=M[0][0];
    for ( size_t i = 0; i < n; ++i ) {
        for ( size_t j = 0; j < m; ++j ) {
            if(Max< M[i][j])
                Max = M[i][j];
        }
    }
    return Max;
}
1
6 / 6 / 5
Регистрация: 19.10.2013
Сообщений: 359
18.11.2016, 18:07  [ТС] 3
zss,
Вывод:

Введите количество строк матрицы: 5
Введите количество столбцов матрицы: 5

Максимальные элементы строк:
83
81
65
80
80
Минимальный среди максимальных: 65
-842150451 -842150451 -842150451 -842150451 -842150451
44 53 83 7 26
75 73 81 0 45
65 18 35 13 9
18 8 35 80 48
28 58 80 79 72
Для продолжения нажмите любую клавишу . . .

Что сделал:
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
88
89
90
91
92
93
94
95
96
97
98
99
// Matrix.cpp : Defines the entry point for the console application.
//
 
#include "stdafx.h"
#include <iostream>
#include <clocale>
#include <cstdlib>
#include <ctime>
 
using namespace std;
 
int ** Create(int n, int m) {
    int ** M = new int *[n];
    for (int i = 0; i < n; ++i) {
        M[i] = new int[m];
    }
    return M;
}
 
void FillRandomNumbers(int **matrix, const int rows, const int columns)
{
    srand((unsigned int)time(0)); // инициализируем ПГСЧ
 
    for (int row = 0; row < rows; row++)
        for (int column = 0; column < columns; column++)
            matrix[row][column] = rand() % 100; // присваиваем СЧ
}
 
void Print(int ** M, int n, int m) {
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < m; ++j) {
            std::cout << M[i][j] << ' ';
        }
        std::cout << std::endl;
    }
}
 
void Process(int ** M, int n, int m) {
    int *max = new int [n];
    max[n] = { 0 };
    int ctr = 0;
    for (int q = 0; q<n; q++)
    {
        int Min = M[0][0];
        Min = M[q][0];
        for (int w = 1; w < m; w++)
        {
            if (Min<M[q][w]) {
                max[ctr] = M[q][w];
                Min = M[q][w];
            }
            else
                max[ctr] = Min;
        }
        ctr++;
    }
    cout << endl << "Максимальные элементы строк:\n";
    for (int wq = 0; wq < n; wq++)
    {
        cout << max[wq] << "\t" << endl;
 
    }
    int a_min = 100000000;
    for (int i = 0; i<n; i++)
    {
        
        if (max[i] < a_min)
            a_min = max[i];
 
    }
    cout << "Минимальный среди максимальных: " << a_min << endl;
}
 
 
 
int main()
{
    setlocale(LC_ALL, "Rus"); // установление русской локали (windows)
 
    int n, m;
 
    std::cout << "Введите количество строк матрицы: ";
    std::cin >> n;
    std::cout << "Введите количество столбцов матрицы: ";
    std::cin >> m;
    int ** A = Create(n, m);
    FillRandomNumbers(A, n, m);
 
    int* S = new int[n]; // Вектор результата
    Process(A, n, m);
 
    for (int i = 0;i<n;i++)
        std::cout << S[i] << ' ';
    std::cout << std::endl;
 
    Print(A, n, m);
    system("pause");
    return 0;
}
Где ошибка? Как убрать этот мусор: -842150451 -842150451 -842150451 -842150451 -842150451?
0
Модератор
Эксперт С++
10254 / 8573 / 5197
Регистрация: 18.12.2011
Сообщений: 22,938
18.11.2016, 18:12 4
А зачем Вам массив S в 89 и 92-94 строках?
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.11.2016, 18:12

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

Ошибка при работе с двумерным динамическим массивом, созданным через функцию
Доброго времени суток. У меня проблема при работе с динамическим массивом, созданным через функцию....

Работа с динамическим массивом
Помогите, пожалуйста. В чем проблема? Компилирует, но выполнять не хочет. Надо вставить элемент в...

Работа с динамическим массивом
Дано: динамический двумерный массив. Определить сумму всех элементов (с помощью функции, массив и...

Работа с двумерным динамичессим массивом
Есть Двумерный динамичесский массив, который вводится рандомно. Нужно чтобы мы вводили 2 числа 1)...


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

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

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