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

Умножение динамических матриц - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 5.00
StupidTrue
46 / 1 / 0
Регистрация: 06.11.2010
Сообщений: 85
06.11.2010, 17:13     Умножение динамических матриц #1
Добрый день
У меня возникли сложности с программой... Помогите пожалуйста
Ситуация сложилась так:
  1. нужно создать и заполнить 2 динамические матрицы
  2. Нужно умножить 2 динамические матрицы
  3. это нужно сделать с помощи функции

В принципе, я организовал некий "код", но при компиляции он выдает матрицу все элементы которой равны нулю...
исправьте пожалуйста ошибку, так как уже просто нету сил и если можно, оптимизируйте мой код)
и обязательно с пояснением(комментариями) =)

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
#include <cstdlib>
#include <iostream>
 
using namespace std;
// создаю функцию которая умножает динамическую матрицу A на B и создает матрицу С, которая =А*Р
long double mnozim(long double **A, long double **P){
// нахожу количество элементов матрицы А(матрицы А Р квадратные и одинакового размера)
    int n=sizeof(*A)/sizeof(long double);
// создаю двухмерный динамический массив - квадратная матрицу С размерами n*n (такими же, как и А Р)
    long double  **C;
    C=new long double *[n];
    for (int i=0; i<n; i++){
        C[i]=new long double [n];
    }
// умножаю матрицу A на матрицу P и присваиваю результату матрицу С
    for (int i=0; i<n; i++){
        for (int j=0; j<n; ++j){
            for (int r=1; r<n; ++r){
                C[i][j]=A[0][r]*P[r][0];
            }
        }
    }
return **C; // ввожу в вызывающе окружение матрицу С
}
 
 
int main()
{
 
      cout<<"BBedite rozmeri"<<endl;
            cout<<"n=m=";
            int n;
            cin>>n;
            /*создаю 2 динамических двухмерных массива(2 квадратные матрицы)*/
      long double  **A;
      long double  **P;
            A=new long double *[n];
            P=new long double *[n];
            for (int i=0; i<n; i++){
                A[i]=new long double [n];
                P[i]=new long double [n];
            }
 
 
 
/* заполняю матрицу А*/
            for (int i=0; i<n; i++){
                for (int j=0; j<n; ++j){
                    A[i][j]=rand()%10;
                }
            }    
/* заполняю матрицу P*/
            for (int i=0; i<n; i++){
                for (int j=0; j<n; ++j){
                    P[i][j]=rand()%10;
                }
            }    
/*создаю матрицу Q в которую будет записыватся результат умнодение A на P (матрица C)*/
    long double  **Q;
    Q=new long double *[n];
    for (int i=0; i<n; i++){
        Q[i]=new long double [n];
    }
// вызываю функцию mnozim
    **Q=mnozim(A, P);
//вывожу матрицу Q
             for (int i=0; i<n; i++){
                    for (int j=0; j<n; ++j){
                        if (j+1<n){
                            cout<<Q[i][j]<<" ";
                        }
                        else {
                           cout<<Q[i][j]<<" "<<endl;
                        }
                    }
            }
 
 
 system("PAUSE");
    return EXIT_SUCCESS; }
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.11.2010, 17:13     Умножение динамических матриц
Посмотрите здесь:

Передача динамических матриц в функцию C++
C++ Умножение матриц
Инициализация динамических матриц в с++ C++
C++ Умножение матриц
Умножение матриц C++
Организация программ по обработке динамических матриц C++
Умножение матриц C++
C++ Перемножение матриц с использованием динамических массивов

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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