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

Умножение матриц - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 27, средняя оценка - 4.78
Soft
4 / 4 / 1
Регистрация: 20.09.2010
Сообщений: 102
11.10.2010, 19:39     Умножение матриц #1
Вычислить:
q = min(2*MA*MB)
где MA, MB – матрицы размером N1xN2. Числа N1 и N2 задаются пользователем в начале работы программы. Все элементы матриц заполнить случайными целыми числами в диапазоне [-5;5].
Программу напишите пожалуйста как можно проще.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.10.2010, 19:39     Умножение матриц
Посмотрите здесь:

C++ Умножение матриц
Умножение матриц C++
C++ Умножение матриц
Умножение матриц C++
Умножение матриц C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
PointsEqual
ниначмуроФ
 Аватар для PointsEqual
832 / 516 / 33
Регистрация: 12.10.2009
Сообщений: 1,915
12.10.2010, 01:00     Умножение матриц #2
хм, если MA(n1 х n2) и MB(n1 х n2) , то если n1=2 и n2 =4 как же их умножать?

количество столбцов MA должно равнятся количеству строк MB. Разве не так?
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
12.10.2010, 01:02     Умножение матриц #3
PointsEqual, Так. А итоговая кол-во строк первой на кол-во столбцов второй
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
12.10.2010, 01:04     Умножение матриц #4
Ну так а задание не корректно. Такие матрицы можно перемножить только в случае, когда N1 = N2.
Soft
4 / 4 / 1
Регистрация: 20.09.2010
Сообщений: 102
12.10.2010, 20:02  [ТС]     Умножение матриц #5
Цитата Сообщение от PointsEqual Посмотреть сообщение
хм, если MA(n1 х n2) и MB(n1 х n2) , то если n1=2 и n2 =4 как же их умножать?

количество столбцов MA должно равнятся количеству строк MB. Разве не так?
Выходит в методичке опечатка. Сделайте тогда так, как должно быть.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
12.10.2010, 20:06     Умножение матриц #6
Soft, Ваши наработки?
Soft
4 / 4 / 1
Регистрация: 20.09.2010
Сообщений: 102
13.10.2010, 01:11  [ТС]     Умножение матриц #7
Все что я смог сделать, остальное не очень знаю как реализовать.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>
#include <conio.h>
#include <cstdlib.h>
#include <ctime.h>
int N; 
int MA[N][N];
int MB [N][N];
 
int Q[N];
int i;
int j;
int main ()
 
{
std::cout <<"vvedite razmernost matric";
std::cin >>N;
    for (i=-5; i<=5; i++)
        for (j=-5; j<=5; j++)
srand(time(NULL));
        {
                MA[i][j]=-5;
        }
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
13.10.2010, 01:14     Умножение матриц
Еще ссылки по теме:

C++ Умножение матриц
C++ Умножение матриц
C++ Умножение матриц

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

Или воспользуйтесь поиском по форуму:
PointsEqual
ниначмуроФ
 Аватар для PointsEqual
832 / 516 / 33
Регистрация: 12.10.2009
Сообщений: 1,915
13.10.2010, 01:14     Умножение матриц #8
Перемножение 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
#include "stdafx.h"
#include <iostream>
#include <iomanip>
 
using namespace std;
 
void matrixmult( int **m1, int m1_row, int m1_col, int **m2, int m2_row, int m2_col, int **m3, int m3_row, int m3_col);
 
void matrixfill( int **m, int row, int col){
        for (int i = 0; i < row; ++i)
            for (int j = 0; j < col; ++j){
                std::cout << "Enter [ " << i << " ][ " << j <<" ] element: ";
                std::cin >> m[i][j];
            }
}
 
        
 
int _tmain(int argc, _TCHAR* argv[])
{
    int row1 = 0;
    int col1 = 0;
 
    std::cout << "Enter number of rows of the first matrix: ";
    std::cin >> row1;
    
    std::cout << "Enter number of columns of the first matrix: ";
    std::cin >> col1;
    
    int **arr1 = new int*[row1];
    for (int i = 0; i < row1; ++i)
        arr1[i] = new int[col1];
 
    matrixfill(arr1,row1,col1);
 
 
 
 
 
 
 
    int row2 = 0;
    int col2 = 0;
 
    std::cout << "Enter number of rows of the first matrix: ";
    std::cin >> row2;
    
    std::cout << "Enter number of columns of the first matrix: ";
    std::cin >> col2;
 
    int **arr2 = new int*[row2];
    for (int i = 0; i < row2; ++i)
        arr2[i] = new int[col2];
 
    matrixfill(arr2,row2,col2);
 
 
 
 
 
    int row3 = row1;
    int col3 = col2;
    
    int **arr3 = new int*[row3];
    for (int i = 0; i < row3; ++i)
        arr3[i] = new int[col3];
 
    for (int i = 0; i < row3; ++i)
            for (int j = 0; j < col3; ++j)
                arr3[i][j] = 0;
 
 
 
 
 
    //если число столбцов первой матрицы равно числу строк второй матрицы
    (col1 == row2) ? matrixmult(arr1,row1,col1, arr2,row2,col2, arr3,row3,col3) : cerr << " Error! ";
    
 
    std::cout << std::endl<< "Result matrix:" << std::endl;
    for (int i = 0; i < row3; ++i){
            for (int j = 0; j < col3; ++j)
                cout << arr3[i][j] << std::setw(3);
        cout << endl;
    }
 
 
 
    cin.get();
    cin.get();
    return 0;
}
 
 
 
void matrixmult( int **m1, int m1_row, int m1_col, int **m2, int m2_row, int m2_col, int **m3, int m3_row, int m3_col){
    for (int k = 0; k < m2_col; ++k)
        for (int i = 0; i < m1_row; ++i)
            for (int j = 0; j < m1_col; ++j)
                m3[i][k] += m1[i][j] * m2[j][k]; 
}
Yandex
Объявления
13.10.2010, 01:14     Умножение матриц
Ответ Создать тему
Опции темы

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