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

Программа с матрицами. Найти минимальное значение среди четных элементов матрицы и сумму положительных элемен-тов матрицы - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Программа с заполнением в файл http://www.cyberforum.ru/cpp-beginners/thread817590.html
Помогите отладить, не смекаю, как исправить. Ошибка где-то в определении массивов, строка 20 выдает ошибку. #include <iostream> #include <cstdio> #include <cstring> #include <ctype.h> #define...
C++ Удаление элемента из списка и поиск элемента Нужно удалить определенный элемент из списка. Найти элемент в списк и вывести на него всю информацию. Вот код. Не знаю как написать эти пункты. #include<iostream> #include <malloc.h> #include... http://www.cyberforum.ru/cpp-beginners/thread817574.html
Удаление элементов вектора C++
как вызвать деструктор? почему не удаляется объект class a { public: a() { std::cout << "c"; } ~a() { std::cout << "d"; };
Занести в двумерный массив значения функции C++
Помогите пожалуйста с задачкой. Занести в двумерный массив значения функции f(x,y)=1/(x+y), o<=x<=30, 1<=y<=20 и вывести его на экран. Код: #include <iostream> #include <conio.h> using...
C++ Сартировка масива http://www.cyberforum.ru/cpp-beginners/thread817544.html
Здравствуйте. Помогите пожалуйста сделать чтобы массив заполнялся бы случайными числами, а не вводить в ручную. Я пытался сделать сам, но не вышло. #include <iostream> #include <string> using...
C++ Работа с матрицей. Написать фунцию которая заполняет заштрихованную область матрицы нулями Задали квадратную матрицу, все элементы которой равны единице. написать фунцию void func (int** arr, int n) которая заполняет заштрихованную область матрицы нулями. Размер массива вводится с... подробнее

Показать сообщение отдельно
Ded_Vasilij
231 / 213 / 15
Регистрация: 01.09.2012
Сообщений: 2,103
24.03.2013, 23:01
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
100
void del_matrix(int** &matrix, int size) //освобождение памяти выделенной под массив
{
    for (int i = 0; i < size; i++)
    {
        delete [] matrix[i];
    }
    delete [] matrix;
    matrix = 0;
}
 
int ** new_matrix(int size)  // выделение памяти под целочисленный массив n*n
{
    int** matrix = 0;
    int i = 0;
    try 
    {
        matrix = new int* [size];
        for (; i < size; i++)
        {
            matrix[i] = new int [size];     
        }
        return matrix;
    }
    catch(bad_alloc e)
    {
        cerr << e.what();
        del_matrix(matrix,i);
    }
}
 
void cin_matrix(int** matrix, int size)//ввод матрицы
    /*int** matrix - двумерный динамический массив
    int size - размер матрицы
    */
{
    for (int i = 0; i < size; i++)
        for (int j = 0; j < size; j++)
        {
            cin >> matrix[j][i];
        }
    cout << endl;
}
 
void print_matrix(int** matrix, int size) //вывод матрицы
{
    for (int i = 0; i < size; i++)
    {
        for (int j = 0; j < size; j++)
        {
            cout << matrix[j][i] << " ";
        }
        cout << endl;
    }
}
int main(int argc, char** argv)
{
    
    int size = 0;
    int** matrix = 0;
 
    if(argc > 1)
    {
        cout << argv[1] << endl;
        matrix = read_file(argv[1],size);
        if (!matrix)
        {
            cout << "error!" << endl;
            return -1;
        }
    }
    else
    {
        cin >> size;
        if (size <= 0)
        {
            cout << "error" << endl;
            return -1;
        }
        matrix = new_matrix(size);
        if(!matrix) 
        {
            cout << "error" << endl;
            return -1;
        }
        cin_matrix(matrix, size);
    }   
    cout << "original matrix" << endl;
    print_matrix(matrix,size);
        int min = 1000;
        int sum = 0;
        for (int i = 0; i < size; i++)
            for (int j = 0; j < size; j++)        
            {
                  if (matrix[i][j]%2 == 0 && matrix[i][j] < min)
                     min = matrix[i][j];
                  if (matrix[i][j] > 0)
                     sum += matrix[i][j];
             }
     cout << "min = " << min << endl << "sum = " << sum;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru