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

Транспонирование матрицы - C++

Восстановить пароль Регистрация
 
DirtyLiar1993
0 / 0 / 0
Регистрация: 05.03.2013
Сообщений: 6
11.03.2013, 21:42     Транспонирование матрицы #1
Начал писать курсовик, мое задание такое:
Создайте приложение для работы с квадратными матрицами, порядок которых достаточно высок, например, 100. Элементы матрицы могут вводиться как с клавиатуры (для матриц низких порядков), так и из файла. Программа может выполнять следующие операции:
1. транспонирование;
2. нахождение обратной матрицы.
3. вычисление определителя (по желанию)

пока я набрасал код первого пункта но что-то не хочет грузиться, мельком появляется черный экран и исчезает, компилятор ошибок не выдает.
можете мне помочь найти ошибку в коде?, а то я еще не очень освоился. програмирую в Borland 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
#include <iostream>
using namespace std;
void main()
{
int mat [20][20];
int size, i, j, temp;
do{
cout<<"\n\nVvedite razmernost matrici: ";
cin>>size ;
} while ( size > 20 );
for ( i=0; i < size; i++ )
{
cout<<"\nVvedite stroku nomer : "<<i+1;
for ( j=0; j < size; j++  )
cin>>mat[i][j];
}
i=1;
do{
j=0;
do{
temp = mat[i][j]; mat[i][j] = mat[j][i]; mat [j++][i ]=temp;
} while ( j < i );
} while ( ++i < size );
for ( i=0; i < size; i++ )
{ cout<<"\n\n";
for ( j=0; j < size; j++ )
cout<< mat[i][j];
}
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.03.2013, 21:42     Транспонирование матрицы
Посмотрите здесь:

Транспонирование матрицы C++
Транспонирование матрицы C++
транспонирование матрицы C++
Транспонирование матрицы C++
C++ Транспонирование матрицы
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Черный ворон
129 / 123 / 6
Регистрация: 31.01.2012
Сообщений: 435
11.03.2013, 22:13     Транспонирование матрицы #2
DirtyLiar1993, закрывалось, потому что Вы никак не тормозили закрытие консоли после отрабатывания программы, а сама программа отрабатывает у Вас, вроде, правильно.
для этого я добавил
C++
1
system("pause");
ну и чуть подправил вывод:
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
#include <iostream.h>
using namespace std;
int main()
{
int mat [20][20];
int size, i, j, temp;
do{
cout<<"Vvedite razmernost matrici: ";
cin>>size ;
} while ( size > 20 );
for ( i=0; i < size; i++ )
{
cout<<"Vvedite stroku nomer "<<i+1<<" : ";
for ( j=0; j < size; j++ )
cin>>mat[i][j];
}
i=1;
do{
j=0;
do{
temp = mat[i][j]; mat[i][j] = mat[j][i]; mat [j++][i ]=temp;
} while ( j < i );
} while ( ++i < size );
for ( i=0; i < size; i++ )
{ cout<<"\n";
for ( j=0; j < size; j++ )
cout<< mat[i][j]<<" ";
}
cout<<endl;
system ("pause");
return 0;
}
Миниатюры
Транспонирование матрицы  
DirtyLiar1993
0 / 0 / 0
Регистрация: 05.03.2013
Сообщений: 6
11.03.2013, 22:39  [ТС]     Транспонирование матрицы #3
Черный ворон, спасибо вам большое!!! действительно работает прекрасно. теперь буду думать как находить обратную.
DirtyLiar1993
0 / 0 / 0
Регистрация: 05.03.2013
Сообщений: 6
23.04.2013, 19:47  [ТС]     Транспонирование матрицы #4
Народ я продолжаю работать над курсовиком, мне нужно найти обратную матрицу квадратной матрицы высокого порядка. Есть код но он для С, а мне надо для С++.
Может кто-нибудь перевести данный код на С++?, хотя на первый взгляд я в коде ничего странного не заметил, вроде все как в С++, однако билдер не хочет запускать этот код вообще. Вот сам код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
double det (double xk[10][10], int razm)   //нахождение определителя
{
int l;
double d;
double sum11=1,sum12=0, sum21=1, sum22=0;
// находим детерминант
        for (int i=0;i<razm;i++)
        {
                sum11=1; l=2*razm-1-i;sum21=1;
        for (int j=0;j<razm;j++)
                {
            sum21*=xk[j][l%razm];
            l--;
            sum11*=xk[j][(j+i)%(razm)];
        }
        sum22+=sum21;
        sum12+=sum11;
    }
    d=sum12-sum22;
return d;
}
Добавлено через 43 минуты
Этот код только для определителя. дальше нужно данную матрину сделать союзной,например :
была:

А= 2 1
5 3
союзная должна выглядеть так:

A= 3 -1
-5 2
То есть одна диагональ просто меняет знак, а в другой элементы меняются местами.
А только потом нужно найти обратную матрицу путем деления каждого элемента союзной матрицы на детерминант (определитель).

Надеюсь на чью нибудь помощь.

Добавлено через 24 минуты
нашел в интернете как найти определитель но опять билдер не запускает:
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
    #include<conio.h>
#include <iostream.h>
#include <stdio.h>
# include <stdlib.h>
#define n 3
int a [n][n];
void main()
{
int i,j;
int d;
 
 
for(i=0;i<n;i++)
for(j=0;j<n;j++)
{printf("Введите элемент матрицы [%d][%d] ",i+1,j+1); scanf("%d",&a[i][j]);}
 
clrscr();
cout<<"Ваша матрица:\n";
   for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
 
printf("%7d",a[i][j]);
puts("\n");
}
 
 
d=((a[0][0]*a[1][1]*a[2][2]) + (a[0][1]*a[1][2]*a[2][0])+ (a[1][0]*a[0][2]*a[2][1]) - (a[2][0]*a[1][1]*a[0][2]) - (a[0][0]*a[2][1]*a[1][2]) - (a[1][0]*a[0][1]*a[2][2]));
printf("определитель равен = %d\n", d);
 
}
Yandex
Объявления
23.04.2013, 19:47     Транспонирование матрицы
Ответ Создать тему
Опции темы

Текущее время: 01:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru