Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/68: Рейтинг темы: голосов - 68, средняя оценка - 4.85
13 / 13 / 4
Регистрация: 01.12.2010
Сообщений: 95

умножение матриц: динамические массивы

01.12.2010, 18:40. Показов 12376. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
прошу помощи: на языке C (не C++) необходимо написать программу умножения матриц, при этом программе передаются размеры матриц, а она должна динамически выделить память под них, принять ввод с клавиатуры или стандартного ввода, после чего выполнить умножение.
Помогите хотя бы в одном: как динамически выделить память под двумерный массив и заполнить его? Само умножение матриц я знаю
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.12.2010, 18:40
Ответы с готовыми решениями:

Умножение матриц(динамические одномерные массивы)
Есть класс: class Array { public: /*Конструкторы*/ Array(Array &tmp);//конструктор копирования Array();...

Указатели и массивы. Индексация с помощью указателей. Передача массивов в функции. Динамические массивы (обработка матриц)
Для каждого элемента , bij, i= 1,...,n , j=1,...,n определяется свой многоугольник местонахождением соответствующего элемента aij (см....

Умножение треугольных матриц«Методы обработки разреженных матриц»
Нужно перемножить треугольные матрицы в обычном виде и в свёрнутом. С обычным проблем нет. Доступ к элементам свёрнутой матрицы...

7
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
01.12.2010, 19:20
Цитата Сообщение от starikNAD Посмотреть сообщение
Помогите хотя бы в одном: как динамически выделить память под двумерный массив и заполнить его? Само умножение матриц я знаю
C
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <stdio.h>
#include <stdlib.h>
int main ()
{
int ROWS,COLUMNS,i;
int **matrix;
scanf ("%d%d", &ROWS, &COLUMNS);
 
matrix=(int*)malloc(sizeof(int*)*ROWS);
for (i=0;i<COLUMNS;i++)
matrix[i]=(int*)malloc(sizeof(int)*COLUMNS);
return 0;
}
и дальше работаешь как с обычным двумерным массивом
C
1
matrix[i][j];

Цитата Сообщение от starikNAD Посмотреть сообщение
Само умножение матриц я знаю
могу помочь

Добавлено через 2 минуты
как освободить выделенную память надо писать?
1
13 / 13 / 4
Регистрация: 01.12.2010
Сообщений: 95
01.12.2010, 19:28  [ТС]
go, пусть Бог продлит дни Вашей жизни!

Добавлено через 2 минуты
насчет самого умножения матриц: я в принципе математику прочел, собираюсь пробовать. Главное - я никак не мог создать массив заданного размера, остальное начну пробовать
А удалять массив - как-то использовать free()?
0
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
01.12.2010, 19:48
C
1
2
3
for ( i=0;i<COLUMNS;i++) // освобождение памяти
free (matrix[i]);
free (matrix);
просто добавь в конце перед (ретурн 0)

Добавлено через 1 минуту
хотя, в принципе, в мэйн-функции это не нужно
1
13 / 13 / 4
Регистрация: 01.12.2010
Сообщений: 95
02.12.2010, 19:54  [ТС]
Уважаемый go, компилятор Borland C++ 3.1 обижает. На строке
matrix=(int *) malloc(sizeof(int *)*ROWS);
сообщает: Cannot convert 'int * ' to 'int * * '
0
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
02.12.2010, 20:24
C
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <stdio.h>
#include <stdlib.h>
int main ()
{
int ROWS,COLUMNS,i;
int **matrix;
scanf ("%d%d", &ROWS, &COLUMNS);
 
matrix=(int**)calloc(sizeof(int*),ROWS); //  указатель пропустил, исправь эту строчку
for (i=0;i<COLUMNS;i++)
matrix[i]=(int*)malloc(sizeof(int)*COLUMNS); 
return 0;
}
кстати добавил calloc
он отличается от malloc тем, что обнуляет предварительно память

Добавлено через 18 минут
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
#include <stdio.h>
#define n 2
#define m 5
#define k 3
 
int main ()
{ int a[n][m], b[m][k], c[n][k],i,j,z;
for (i=0;i<n;i++) // ввод рандомом
for (j=0;j<m;j++)
a[i][j]=rand ()%5;
 
for (i=0;i<m;i++)
for (j=0;j<k;j++)
b[i][j]=rand ()%5;
 
 
      for (i=0;i<n;i++)
for (j=0;j<k;j++)
{ c[i][j]=0; //обнуляем элемент,  в который будет производится запись перемножения строка на                       //столбец
for (z=0;z<m;z++)
c[i][j]+=a[i][z]*b[z][j]; //записываем сумму  умножая поочередно элементы строки и столбца
}
 
 
for (i=0;i<n;i++)
{ puts ("\n");
for (j=0;j<k;j++)
printf ("%10d", c[i][j]);
}
 
system ("Pause");
return 0;
}
вот умножения
измените, добавив динамический ввод,
думаю это не сложно
если не получится - помогу
2
13 / 13 / 4
Регистрация: 01.12.2010
Сообщений: 95
02.12.2010, 21:24  [ТС]
go,
я внес изменение:
C
1
2
3
matrix=(int**)calloc(sizeof(int*),ROWS); //  указатель пропустил, исправь эту строчку
for (i=0;i<ROWS;i++)   // здесь заменил COLUMNS на ROWS
matrix[i]=(int*)malloc(sizeof(int)*COLUMNS);
иначе при умножении матрицы 3х3 на матрицу 3х1 данные получались неверниые

Добавлено через 10 минут
и еще одно: как правильно объявить функцию mmult?
я написал в прототипе
C
1
void mmult(int r, int s, int c, int ** m1, int ** m2, int **m3)
и вызываю как
C
1
mmult(r,s,c,m1,m2,m3)
Добавлено через 1 минуту
а функция "не видит" матриц, числа не соответствуют (хотя ввод в main выполнен правильно, я проверил)
0
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
02.12.2010, 21:49
C
1
*(*(mt+i)+j) //mt[i][j]
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.12.2010, 21:49
Помогаю со студенческими работами здесь

Динамические массивы и функции. Динамические массивы.
Дана матрица 6х8 целого типа. Создать одномерный массив, содержащий элементы матрицы, кратные числу, введенному с клавиатуры.

Структуры, массивы, указатели, динамические массивы структур
Помогите с решением задачи (прикрепляю условие). Заранее спасибо.

Умножение матриц
Я решил написать программу для умножения двух матриц ,написать я не смог только ту часть в которой нужно было производить умножение ,я...

Умножение матриц
Найти произведение k квадратных матриц А1*А2*...Аk. Процедура: вычисление произведения двух матриц.

Умножение матриц
надо получить матрицу А*В


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru