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

Перемножение матриц. Ошибка в коде(?) - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Русификация вывода http://www.cyberforum.ru/cpp-beginners/thread1115779.html
Доброго времени суток. Написал такую программу: #include <iostream> #include <string> #include <iomanip> #include <cmath> using namespace std; #include "calculateModule.h" int main() {
C++ Вызывть метод одного потока из другого потока Здравствуйте, подскажите пожалуйста, как можно реализовать такую штуку : есть один поток(1), который вызывает метод у обьекта, этот метод создает второй поток(2) и в новом потоке(2) что-то делает, потом по окончанию своей работы(2 - поток), нужно вызвать метод который выполнился б уже в первом(1) потоке, тоесть второй поток впихивает метод в первый. Вообщем можно ли такое? http://www.cyberforum.ru/cpp-beginners/thread1115774.html
Задано натуральное число N. Для каждого из чисел от 1 до N требуется найти количество его делителей C++
Задано натуральное число N. Для каждого из чисел от 1 до N требуется найти количество его делителей. Исходные данные число N от 1 до 1 млн Результат N чисел через пробел - количества делителей каждого из чисел от 1 до N Пример
Есть n-значное число нужно сложить сложить все его цифры C++
Как такое реализовать?
C++ Вычислить количество отрицательных элементов массива http://www.cyberforum.ru/cpp-beginners/thread1115755.html
в одновременном массиве ,состоящем из n вещественных элементов ,1)вычислить количество отрицательных элементов массива 2)сумму модулей элементов массива,расположенных после минимального по модулю элемента заменить все отрицательные элементы массива их квадратами и упорядочить элементы массива по возрастанию С++
C++ Статический самовызов Всем привет. Представьте такую ситуацию: У меня в программе есть статический класс connections, который хранит коллекцию элементов типа connection. В некоторой функции класса connection возможна ситуация вызова своего же метода с помощью connections, а также побуждение класса connections произвести уничтожение объекта connection побудившего это действие. Скажите, пожалуйста, правильный ли... подробнее

Показать сообщение отдельно
M-39
 Аватар для M-39
3 / 3 / 1
Регистрация: 14.11.2013
Сообщений: 31
10.03.2014, 21:52     Перемножение матриц. Ошибка в коде(?)
Ребята, не могу сообразить в чем беда. Ругается на входные матрицы, хотя оные объявлены вроде как. В printf предполагался вывод их как дробь с плавающей точкой.
Задание звучит так: перемножить квадратные матрицы A * B = С. А и В заполняются по правилу А[i,j]=i, i=1..n; B[i,j]=1/j, j=1..n. Вывести угловые элементы матрицы C и посчитать производительность программы.
В чем ошибка? И как в здесь посчитать производительность? Заранее благодарна за внимание!

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
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
 
//A*B=C,  n=40,500,2000
//a[i,j]=i, i=1..n;
//b[i,j]=1/j, j=1..n;
//calculate corner elements of C and time
 
int main() {
 
const n=4;
unsigned long long i,j,k;
//double A[n][n],B[n][n],C[n][n];
for(int i=1;i<=n;i++)
{  double** A=new double* [n];
   double** B=new double* [n];
   double** C=new double* [n];
   for(int j=1;j<=n;j++)
   {  A[i][j]=i;
      B[i][j] = 1/j;
   }
}
 
 
for(i=1;i<=n;i++)
{  for(j=1;j<=n;j++)
      printf("%d\t",A[i][j]);
      printf("\n");
}
 
for(i=0;i<n;i++)
{  for(j=0;j<n;j++)
      printf("%d\t",B[i][j]);
      printf("\n");
}
 
 clock_t time;
 time = clock();
 
for (i = 0; i < n; i++)
{   for (k = 0; k < n; k++)
    {   for (j = 0; j < n; j++)
        {   C[i][j] += A[i][k] * B[k][j];
        }
    }
}
 
  /*for(i=0;i<n;i++){
                for(j=0;j<n;j++)
                         printf("%d\t",C[i][j]);
                printf("\n");}; */
 
 printf("%d\n",C[1][1]);
 printf("%d\n",C[1][n]);
 printf("%d\n",C[n][1]);
 printf("%d\n",C[n][n]);
 
 time = clock() - time;
    printf("time=%f\n", (double)time/CLOCKS_PER_SEC);
    system("pause");
 
    return 0;
 
           }
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 10:02. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru