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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
AlexBalRus
0 / 0 / 0
Регистрация: 09.02.2014
Сообщений: 5
#1

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

09.02.2014, 18:25. Просмотров 609. Ответов 2
Метки нет (Все метки)

Программа не так считает итоговую матрицу (C=A*B). Наверно я что-то не понимаю ...

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
#include <iostream>
#include <conio.h>
using namespace std;
 
void Gen(int **A, int **B, int n, int m, int k);
void Vivod(int **A, int **B, int n, int m, int k);
void Multi(int **A, int **B,double **C,  int n, int m, int k);
 
void main(){
    setlocale(LC_ALL,"Russian");
    int n, m, k, **A, **B; double **C;
    cout << "                           Перемножение неквадратных матриц\n";
    cout << "Введите число строк первой матрицы n=";
    cin >> n;
    cout << "Введите число столбцов первой матрицы m=";
    cin >> m;
    cout << "\tДля успешного перемножения матриц число столбцов первой матрицы\n";
    cout << "\tдолжно быть равно числу строк второй матрицы(что уже учтено)!\n";
    cout << "Ведите число столбцов второй матрицы k=";
    cin >> k; cout << "\n";
    A = new int*[n];
    B = new int*[m];
    C = new double*[n];
    Gen(A, B, n, m, k);
    Vivod(A, B, n, m, k);
    Multi(A, B, C, n, m, k);
    for (int i = 0; i < n; i++){
        delete[] A[i];
        delete[] C[i];
}
    for (int i = 0; i < m; i++){
        delete[] B[i];
        }
    delete A, B, C;
 
 
 
    _getch();
}
 
void Gen(int **A, int **B, int n, int m, int k) {
    for (int i=0;i<n;i++){
        A[i] = new int[m];
 
        for (int j=0;j<m;j++){
            A[i][j] = rand() % 10;
}}
 
    for (int i = 0; i<m; i++){
        B[i] = new int[k];
 
        for (int j = 0; j<k; j++){
            B[i][j] = rand() % 10;
        }
    }
}
 
void Vivod(int **A, int **B, int n, int m, int k){
    cout << "A=" << endl;
    for (int i = 0; i<n; i++){
        
 
        for (int j = 0; j<m; j++){
            cout << A[i][j] << " ";
        } cout << "\n";
    }
    cout << "\nB=" << endl;
    for (int i = 0; i<m; i++){
 
        for (int j = 0; j<k; j++){
            cout << B[i][j] << " ";
        } cout << "\n";
    }
}
 
void Multi(int **A, int **B,double **C, int n, int m, int k){
    cout << "\nC=A*B=\n";
    for (int i = 0; i < n; i++){
        C[i] = new double[k];
        for (int j=0;j<k;j++){
                    C[i][j] = 0;
                    for (int ii = 0; ii < m; ii++){
                        
                C[i][j] += A[i][ii] * B[ii][k];
            }
            cout << C[i][j] << " ";
        } cout << "\n";
        }
        
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.02.2014, 18:25
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Перемножение неквадратных матриц с использованием динамического массива (C++):

Перемножение матриц с использованием динамических массивов - C++
Всем здравствуйте) Программа не считает матрицу С (С=A*B). В чём дело не понимаю. #include &lt;iostream&gt; #include &lt;conio.h&gt; using...

Переписать код с использованием динамического массива - C++
вот такой код.. он должен убирать все, что находится в скобках. без дин. массива, он работает, но задание состоит в том, чтоб запихнуть это...

Переделать код с использованием динамического массива - C++
#include&lt;iostream&gt; #include &lt;stdio.h&gt; using namespace std; int main( ) { int const n=3,m=3; int...

Разработать программу создания динамического массива с использованием функций - C++
Разработать программу создания массива с использованием функций Элементы матрицы заполняются псевдослучайными числами. В программе...

Перемножение матриц - C++
Доброго времени суток! У меня есть две матрицы: первая k x m и вторая u x s размерностей. Нужно их перемножить. Подскажите, пожалуйста, в...

Перемножение матриц. - C++
Нужен код для перемножения матрицы и столбца за минимально возможное время. Порядок матрицы ( и столбца ) огромен - около 100000....

2
Amandosov
Знаток
156 / 156 / 65
Регистрация: 18.11.2012
Сообщений: 411
Записей в блоге: 2
10.02.2014, 20:13 #2
Ошибка здесь:
Цитата Сообщение от AlexBalRus Посмотреть сообщение
void Multi(int **A, int **B,double **C, int n, int m, int k){
cout << "\nC=A*B=\n";
for (int i = 0; i < n; i++){
C[i] = new double[k];
for (int j=0;j<k;j++){
C[i][j] = 0;
for (int ii = 0; ii < m; ii++){
C[i][j] += A[i][ii] * B[ii][k];
}
cout << C[i][j] << " ";
} cout << "\n";
}
Должно быть так:
C++
1
C[i][j] += A[i][ii] * B[ii][j];
1
AlexBalRus
0 / 0 / 0
Регистрация: 09.02.2014
Сообщений: 5
10.02.2014, 22:55  [ТС] #3
Спасибо !!!
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.02.2014, 22:55
Привет! Вот еще темы с ответами:

Перемножение матриц - C++
Доброго времени суток. Подскажите как разобраться с перемножением матриц, если есть 2 матрицы размерностью МхМ (М = 2000-5000),...

Перемножение матриц - C++
Перемножить матрицы m*n и m*p где заданы константы n=1000,m=1100,p=12000

Перемножение матриц - C++
Привет. Помогите пожалуйста решить нетрудную задачу.Заранее спасибо. (если можно рабочую версию) Дано два двумерных массива ...

Перемножение матриц - C++
Даны две квадратные матрицы.Напишите программу перемножающую матрицы по правилам перемножения матриц. У меня есть программа. но мне...


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

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

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