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

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 28, средняя оценка - 4.68
Kyter
0 / 0 / 0
Регистрация: 13.05.2010
Сообщений: 22
#1

Функции (Расчет определителя матрицы) - C++

25.05.2010, 16:39. Просмотров 3624. Ответов 20
Метки нет (Все метки)

Задание: Ввести с клавиатуры матрицу 4*4 и подсчитать ее определитель. Процедуру подсчета определителя оформить в виде функции.
во я написал программу, но она не правельно работает, кто может подскажите в чем ошибка:
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
#include <stdio.h>
#include <conio.h>
#include <math.h>
#include <alloc.h>
 
float mat(float **a, int n)
{ int i,j;
float s,d,f,g;
  i=1;
  j=1;
s=((a[i+2][j+2]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+2])*a[i+1][j+1]-(a[i+2][j+1]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+1])*a[i+1][j+2]+(a[i+2][j+1]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j+1])*a[i+1][j+3]);
d=((a[i+2][j+2]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+2])*a[i+1][j]-(a[i+2][j]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j])*a[i+1][j+2]+(a[i+2][j]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j])*a[i+1][j+3]) ;
f=((a[i+2][j+1]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+1])*a[i+1][j]-(a[i+2][j]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j])*a[i+1][j+1]+(a[i+2][j]*a[i+3][j+1]-a[i+2][j+1]*a[i+3][j])*a[i+1][j+3]);
g=((a[i+2][j+1]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j+1])*a[i+1][j]-(a[i+2][j]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j])*a[i+1][j+1]+(a[i+2][j]*a[i+3][j+1]-a[i+2][j+1]*a[i+3][j])*a[i+1][j+2]);
n=(s*a[i][j])-(d*a[i][j+1])+(f*a[i][j+2])+(g*a[i][j+3]);
 
return(n);
}
 
 
void main ()
{
clrscr();
float **b,z;
int i,j;
b=(float**)malloc(80*(sizeof(float*)));
 
for (i=1;i>4;i++)
{
 for (j=1;j>4;j++)
 {
   scanf("%d",&b[i][j]);
 }
}
z=mat(b,4);
printf("%f",z);
getch();
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.05.2010, 16:39
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Функции (Расчет определителя матрицы) (C++):

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

Вычисление определителя матрицы N*N - C++
Дорогие форумчане, никто не подскажет как вычислить определитель квадратной матрицы, сам код не нужен, только алгоритм. Насколько я слышал...

Нахождение детерминанта (определителя) матрицы - C++
У меня вот код есть для нахождения детерминанта (определителя) матрицы 5х5 :) а как сделать, чтобы я мог сам ввести данные матрицы? ...

Вычисление следа матрицы и определителя - C++
воббщем надо реализовать вычисление следа матрицы и определителя алгоритм для следа : #include &lt;stdio.h&gt; typedef int *pInt; ...

Считывание и запись определителя матрицы - C++
в файле записан массив , его надо считать и найти его определитель, и записать его в другой файл. программа не хочет считывать данные. ...

Исправить код c++ ,нахождение определителя матрицы - C++
Необходимо найти определитель матрицы,выдает ошибку. Так же ,может кто предложит свой код нахождения определителя матрицы,нужно срочно. ...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
kazak
3035 / 2356 / 155
Регистрация: 11.03.2009
Сообщений: 5,402
Завершенные тесты: 1
25.05.2010, 16:50 #2
Цитата Сообщение от Kyter Посмотреть сообщение
b=(float**)malloc(80*(sizeof(float*)));
=>
C
1
2
3
4
5
6
7
b = (float**)calloc(4, sizeof(float*));
for (i = 0; i < 4; i++)
   b[i] = (float*)calloc(4, sizeof(float));
/*в конце программы*/
for (i = 0; i < 4; i++)
   free(b[i]);
free(b);
0
Kyter
0 / 0 / 0
Регистрация: 13.05.2010
Сообщений: 22
25.05.2010, 16:59  [ТС] #3
Эти цыклы на всю программу ставить или отдельно писать?
Всеравно выводит ответ 0,00000000, хоть какую матрицу пиши
0
kazak
3035 / 2356 / 155
Регистрация: 11.03.2009
Сообщений: 5,402
Завершенные тесты: 1
25.05.2010, 17:01 #4
Первые три строчки вместо b=(float**)malloc(80*(sizeof(float*)));
Последние три перед getch().
1
Kyter
0 / 0 / 0
Регистрация: 13.05.2010
Сообщений: 22
25.05.2010, 17:07  [ТС] #5
Так и сделал, но ответ выдает 0,000000, может с ф-цией где-от ошибка?
0
kazak
3035 / 2356 / 155
Регистрация: 11.03.2009
Сообщений: 5,402
Завершенные тесты: 1
25.05.2010, 17:34 #6
Цитата Сообщение от Kyter Посмотреть сообщение
float mat(float **a, int n)
{ int i,j;
float s,d,f,g;
i=1;
j=1;
s=((a[i+2][j+2]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+2])*a[i+1][j+1]-(a[i+2][j+1]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+1])*a[i+1][j+2]+(a[i+2][j+1]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j+1])*a[i+1][j+3]);
d=((a[i+2][j+2]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+2])*a[i+1][j]-(a[i+2][j]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j])*a[i+1][j+2]+(a[i+2][j]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j])*a[i+1][j+3]) ;
f=((a[i+2][j+1]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+1])*a[i+1][j]-(a[i+2][j]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j])*a[i+1][j+1]+(a[i+2][j]*a[i+3][j+1]-a[i+2][j+1]*a[i+3][j])*a[i+1][j+3]);
g=((a[i+2][j+1]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j+1])*a[i+1][j]-(a[i+2][j]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j])*a[i+1][j+1]+(a[i+2][j]*a[i+3][j+1]-a[i+2][j+1]*a[i+3][j])*a[i+1][j+2]);
n=(s*a[i][j])-(d*a[i][j+1])+(f*a[i][j+2])+(g*a[i][j+3]);
return(n);
}
C
1
2
3
4
5
6
7
8
9
10
11
12
float mat(float **a)
{ int i,j;
float s,d,f,g,det;
 i=0;
 j=0;
s=((a[i+2][j+2]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+2])*a[i+1][j+1]-(a[i+2][j+1]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+1])*a[i+1][j+2]+(a[i+2][j+1]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j+1])*a[i+1][j+3]);
d=((a[i+2][j+2]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+2])*a[i+1][j]-(a[i+2][j]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j])*a[i+1][j+2]+(a[i+2][j]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j])*a[i+1][j+3]) ;
f=((a[i+2][j+1]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+1])*a[i+1][j]-(a[i+2][j]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j])*a[i+1][j+1]+(a[i+2][j]*a[i+3][j+1]-a[i+2][j+1]*a[i+3][j])*a[i+1][j+3]);
g=((a[i+2][j+1]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j+1])*a[i+1][j]-(a[i+2][j]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j])*a[i+1][j+1]+(a[i+2][j]*a[i+3][j+1]-a[i+2][j+1]*a[i+3][j])*a[i+1][j+2]);
det=(s*a[i][j])-(d*a[i][j+1])+(f*a[i][j+2])+(g*a[i][j+3]);
return det;
}
Цитата Сообщение от Kyter Посмотреть сообщение
for (i=1;i>4;i++)
{
for (j=1;j>4;j++)
{
scanf("%d",&b[i][j]);
}
}
C
1
2
3
4
5
6
7
for (i=1;i<4;i++)
{
 for (j=1;j<4;j++)
 {
   scanf("%f",&b[i][j]);
 }
}
Цитата Сообщение от Kyter Посмотреть сообщение
z=mat(b,4);
z=mat(b);
0
Kyter
0 / 0 / 0
Регистрация: 13.05.2010
Сообщений: 22
26.05.2010, 06:52  [ТС] #7
Сделал, как Вы сказали, но теперь, программа вообще не запускается, хотя ошибок не найдено
0
kazak
3035 / 2356 / 155
Регистрация: 11.03.2009
Сообщений: 5,402
Завершенные тесты: 1
26.05.2010, 11:37 #8
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
#include <stdio.h>
#include <conio.h>
#include <math.h>
#include <alloc.h>
 
float mat(float **a)
{
   int i, j;
   float s, d, f, g, det;
   i=0;
   j=0;
   s=((a[i+2][j+2]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+2])*a[i+1][j+1]-(a[i+2][j+1]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+1])*a[i+1][j+2]+(a[i+2][j+1]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j+1])*a[i+1][j+3]);
   d=((a[i+2][j+2]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+2])*a[i+1][j]-(a[i+2][j]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j])*a[i+1][j+2]+(a[i+2][j]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j])*a[i+1][j+3]) ;
   f=((a[i+2][j+1]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j+1])*a[i+1][j]-(a[i+2][j]*a[i+3][j+3]-a[i+2][j+3]*a[i+3][j])*a[i+1][j+1]+(a[i+2][j]*a[i+3][j+1]-a[i+2][j+1]*a[i+3][j])*a[i+1][j+3]);
   g=((a[i+2][j+1]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j+1])*a[i+1][j]-(a[i+2][j]*a[i+3][j+2]-a[i+2][j+2]*a[i+3][j])*a[i+1][j+1]+(a[i+2][j]*a[i+3][j+1]-a[i+2][j+1]*a[i+3][j])*a[i+1][j+2]);
   det=(s*a[i][j])-(d*a[i][j+1])+(f*a[i][j+2])+(g*a[i][j+3]);
 
   return det;
}
 
void main ()
{
   clrscr();
   float **b,z;
   int i,j;
 
   b = (float**)calloc(4, sizeof(float*));
   for (i = 0; i < 4; i++)
      b[i] = (float*)calloc(4, sizeof(float));
 
   for (i = 0; i < 4; i++)
   {
      for (j = 0; j < 4; j++)
      {
         scanf("%f",&b[i][j]);
      }
   }
   z=mat(b);
   printf("%.2f",z);
   for (i = 0; i < 4; i++)
      free(b[i]);
   free(b);
   getch();
}
0
Kyter
0 / 0 / 0
Регистрация: 13.05.2010
Сообщений: 22
26.05.2010, 11:55  [ТС] #9
Это у меня лаг или чтот о с программой, она так и не запускается?
0
kazak
3035 / 2356 / 155
Регистрация: 11.03.2009
Сообщений: 5,402
Завершенные тесты: 1
26.05.2010, 11:58 #10
Что за компилятор? У меня работает.
0
Kyter
0 / 0 / 0
Регистрация: 13.05.2010
Сообщений: 22
26.05.2010, 12:14  [ТС] #11
А где посмотреть, какой компелятор?
0
kazak
3035 / 2356 / 155
Регистрация: 11.03.2009
Сообщений: 5,402
Завершенные тесты: 1
26.05.2010, 12:19 #12
Как программа называется, где ты запускаешь код?
0
Kyter
0 / 0 / 0
Регистрация: 13.05.2010
Сообщений: 22
26.05.2010, 13:38  [ТС] #13
А, на c++
0
neske
1495 / 862 / 82
Регистрация: 26.03.2010
Сообщений: 2,951
26.05.2010, 13:41 #14
Это язык программирования, вас же просят сказать название среды, в которой вы работаете.
К примеру, Visual Studio, CodeBlocks и т.д.
0
Kyter
0 / 0 / 0
Регистрация: 13.05.2010
Сообщений: 22
26.05.2010, 13:54  [ТС] #15
Хм, я понимаю, кем вы сейчас меня считаете, но незнаю как называется, выглядит также, как турбо паскаль (консолька)
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.05.2010, 13:54
Привет! Вот еще темы с ответами:

Нужен пример нахождения определителя матрицы - C++
Подскажите пожалуйста простенький пример нахождения определителя матрицы?

Код вычисления определителя матрицы до 10-го порядка - C++
Мне очень нужен код программы для вычисления определителя матрицы до 10-го порядка.

Нахождение определителя матрицы методом гаусса - C++
Нахождение определителя методом гауса #include &lt;stdio.h&gt; #include&lt;locale.h&gt; #include&lt;math.h&gt; #include&lt;conio.h&gt; int main() { ...

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


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
26.05.2010, 13:54
Ответ Создать тему
Опции темы

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