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

Умножение произвольного количества матриц - C++

Восстановить пароль Регистрация
 
ulian
0 / 0 / 0
Регистрация: 28.11.2012
Сообщений: 53
17.01.2013, 21:52     Умножение произвольного количества матриц #1
Помоги написать программу. В кратце о задании : Нужно написать программу которое умножает произвольное количество матриц, произвольного размера и содержания. Все параметры вводятся с клавиатуры(кол-во матриц, размер и их содержания).С++ Желательно через обычные функции, что бы не сложно читался

Добавлено через 2 часа 54 минуты
помогите, до послезавтра нужно сдать(

Добавлено через 2 часа 3 минуты
попробовал написать код - работает только для квадратных матриц, если разных размеров по типу(2на3)*(3на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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
#include <iostream>
#include <time.h>
using namespace std;
//================================ Input function ===========================================
void input(int **matrix, int& row, int& column)
{           // (*matrix)[50] - pointer for matrix and adresses for row and column
    for (int i = 0;i < 50;i++)
        {
            matrix[i] = new int[50];
        }
    do
    {                                                       // cycle for wright input matrix
        cout << " Enter number of rows: " << endl;          
        cin>> row;                                          // input number of rows
        cout << " Enter number of columns: " << endl;
        cin>> column;                                       // input number of columns
        if ((row < 1) || (column < 1))                      // case if entered zero matrix
            cout << " You've entered a zero matrix. Try another. " << endl;
    } while ((row < 1) && (column < 1));
    cout<<"enter element of matrix:"<<endl;
    for(int m = 0;m < row; m++) 
        for(int n = 0;n < column; n++)
            cin>> matrix[m][n];
            
        
        
    
}
//================================ Output function ==========================================
void output(int **matrix, int row, int column)
{           // (*matrix)[50] - pointer for matrix 
    for(int m = 0;m < row; m++)                             // cycle for output rows
    {
        for(int n = 0;n < column; n++)                      // cycle for output columns
            cout << matrix[m][n] <<" ";                     // output matrix
        cout << endl << endl;                               // move cursor to the new line
    }
}
//================================ Product function =========================================
void product(int **matrix1, int **matrix2, int **matrixres, 
                            int row1, int row2, int column1, int column2)
{       // (*matrix1)[50], (*matrix2)[50], (*matrixres)[50]  - pointers for matrixes 
    if (column1 != row2)                                    // case for matching matrixes
        cout << " Product is impossible. Please, try again. " << endl;
    else                                                    // main case
    {
        for(int m = 0;m < row1; m++)                        // choose m row-vector
            for(int n = 0;n < column2; n++)                 // choose n column-vector
                for(int index = 0;index < column1; index++) // index of element
                    matrixres[m][n] += matrix1[m][index] * matrix2[index][n];
                                                            // scalar product of vectors
        for(int i = 0;i < row1;i++)                         // inputing result matrix to 1st matrix
            for(int j = 0;j < column2;j++)                  // element by element
                matrix1[i][j] = matrixres[i][j];
    }
}
//================================ Zeroing function ============================================
void zeroing(int **matrixres)
{
    for (int i = 0;i < 50;i++)
        matrixres[i] = new int[50];
    for(int i = 0;i < 50;i++)                               // zeroing matrix
        for(int j = 0;j < 50;j++)
            matrixres[i][j] = 0;
}
//================================ Main function ============================================
int main()
{
    char y;                                                 // variable for repeating the program
    int num;                                                // number of matrixes
    int **matrix1 = new int *[50], **matrix2 = new int *[50], **matrixres = new int *[50];  // arrays for matrixes
    int row1, row2;                                         // rows of matrixes
    int column1, column2;                                   // columns of matrixes
    do
    {                                                       // cycle to repeat the program
        zeroing(matrixres);                                 // zeroing matrix
        cout << " Enter number of matrixes: " << endl;          
        cin>> num;                                          // input number of matrixes
        if (num <= 1)                                       // case when entered less than 1 matrix 
            cout << " You've entered an incorrect number of matrix. Try another. " << endl;
        else
        {
            cout << " Enter matrix 1: "  << endl;
            input(matrix1, row1, column1);
            for(int i = 1;i < num;i++)                      // cycle for more than 1 matrix
            {                           
                cout << " Enter matrix " << i + 1 << ": "  << endl;
                if (i >= 2)
                
                    input(matrix2, row1, column1);  
                else
                    input(matrix2, row2, column2); 
                product(matrix1, matrix2, matrixres, row1, row2, column1, column2);                                     // matrix product               
                zeroing(matrixres);                         // zeroing matrix
            }                                               
            cout << " Matrixes production: "  << endl;
            output(matrix1, row1, column2);                 // output result of product
        }
        for (int i = 0; i < 50;i++)
        {
            delete[]matrix1[i];
            delete[]matrix2[i];
            delete[]matrixres[i];
        }
        delete[]matrix1;
        delete[]matrix2;
        delete[]matrixres;
        cout << " Do you wish to continue? y - yes, n - no "<< endl;
        cin >> y;                                           // propose to repeat the program
        system("cls");                                      // clear screen
    } while (y == 'y');
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.01.2013, 21:52     Умножение произвольного количества матриц
Посмотрите здесь:

C++ Умножение матриц
C++ Умножение матриц
Умножение матриц C++
умножение 3 матриц C++
C++ Умножение любого количества матриц
C++ Умножение матриц
C++ Умножение матриц
Умножение матриц C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Invader_Zim
Twilight Parasite
 Аватар для Invader_Zim
153 / 149 / 2
Регистрация: 21.07.2011
Сообщений: 907
17.01.2013, 22:31     Умножение произвольного количества матриц #2
ulian, реализуй для двух матриц, и повторяй в цикле. Ну или перегрузи оператор *. Используй классы.
ulian
0 / 0 / 0
Регистрация: 28.11.2012
Сообщений: 53
17.01.2013, 23:09  [ТС]     Умножение произвольного количества матриц #3
я пробовал, но тогда перестает работать для квадратных матриц когда я задаю умножение произвольного размера.
просто у меня ошибка где-то в функции умножения матриц, а я не могу понять где.
Yandex
Объявления
17.01.2013, 23:09     Умножение произвольного количества матриц
Ответ Создать тему
Опции темы

Текущее время: 04:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru