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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Сформировать из матрицы два одномерных массива... http://www.cyberforum.ru/cpp-beginners/thread1092801.html
Заданы матрица А размером N  N. Сформировать два одномерных массива. В один переслать по строкам верхний треугольник матрицы, включая элементы главной диагонали, в другой – нижний треугольник. Распечатать верхний и нижний треугольники по строкам. Добавлено через 1 минуту код на С++ надо
C++ Задачи , построенные с использованием функций С++ Доброго времени суток форумчане ! "Подтолкните" в решении следующих задач , я забуксовал :) 1. Реализовать функцию, которая принимает массив (плюс его длину) , а также число n , и возвращает индекс числа в массиве или -1 , если такого числа нет. Структура : int Search (int a , const int n, const int key); 2. Реализовать функцию, которая принимает массив и выводит на экран те элементы ,... http://www.cyberforum.ru/cpp-beginners/thread1092791.html
C++ Работа с двоичными файлами, организация ввода-вывода структурированной информации/
Сформировать двоичный файл из элементов, заданной в варианте структуры, распечатать его содержимое, выполнить удаление и добавление элементов в соответствии со своим вариантом, используя для поиска удаляе-мых или добавляемых элементов функцию. Формирование, печать, добавление и удаление элементов оформить в виде функций. Предусмотреть сообщения об ошибках при открытии файла и выполнении операций...
C++ Написать конструктор
#include <stdio.h> #include <conio.h> #include <windows.h> #include "Collection.h" void main() { SetConsoleCP(1251); SetConsoleOutputCP(1251);
C++ написать программу для вычисления значений функции F(x) для х, изменяющегося в интервале от A до B с шагом DEL. http://www.cyberforum.ru/cpp-beginners/thread1092766.html
С использованием оператора цикла с предусловием написать программу для вычисления значений функции F(x) для х, изменяющегося в интервале от A до B с шагом DEL. F=a*x*x+b/c при x>1 и с!=0 F=(x-a)/((x-c)(x-c)) при х < 1.5 и c ==0 F=x*x/(c*c) в остальных случаях Собственно только начал изучать с++, поэтому возникают вопросы даже по таким, довольно легким, задачам. Спасибо.
C++ Требуется найти наибольший общий делитель двух чисел Фибоначчи. ЗАДАЧА №384 Числа Фибоначчи - 3 (Время: 1 сек. Память: 16 Мб Сложность: 52%) Последовательностью Фибоначчи называется последовательность чисел F0 = 0, F1 = 1, … , Fk = Fk-1 + Fk-2 (k > 1). Требуется найти наибольший общий делитель двух чисел Фибоначчи. Входные данные подробнее

Показать сообщение отдельно
AlexBalRus
 Аватар для AlexBalRus
0 / 0 / 0
Регистрация: 09.02.2014
Сообщений: 5
09.02.2014, 18:25     Перемножение неквадратных матриц с использованием динамического массива
Программа не так считает итоговую матрицу (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";
        }
        
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 12:42. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru