Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
DirtyLiar1993
0 / 0 / 0
Регистрация: 05.03.2013
Сообщений: 6
1

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

11.03.2013, 21:42. Просмотров 774. Ответов 3
Метки нет (Все метки)

Начал писать курсовик, мое задание такое:
Создайте приложение для работы с квадратными матрицами, порядок которых достаточно высок, например, 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];
}
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.03.2013, 21:42
Ответы с готовыми решениями:

Транспонирование матрицы
Транспонировать матрицу(сделать строки столбцами) z = \begin{vmatrix} 2 &amp; 5 &amp;...

Транспонирование матрицы
Что-то я совсем запуталась,не могу понять как транспонировать матрицу:/...

Транспонирование матрицы
int _tmain(int argc, _TCHAR* argv) { const int n=5; int a;...

Транспонирование матрицы.
Помогите с простенькой задачей!! ПОЖАЛУЙСТА Нужно написать программу на С++,...

Транспонирование матрицы
Здравствуйте! Пишу функцию для транспонирования матрицы... Вот код: void...

3
Черный ворон
131 / 125 / 57
Регистрация: 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;
}
1
Миниатюры
Транспонирование матрицы  
DirtyLiar1993
0 / 0 / 0
Регистрация: 05.03.2013
Сообщений: 6
11.03.2013, 22:39  [ТС] 3
Черный ворон, спасибо вам большое!!! действительно работает прекрасно. теперь буду думать как находить обратную.
0
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);
 
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.04.2013, 19:47

Транспонирование матрицы
Двумерные массивы: 2)Из матрицы X=( xi,k) построить матрицу Y=( yi,k),...

Транспонирование матрицы
Транспонировать матрицу x.

Транспонирование матрицы
#include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; void transponirovanie(int**mass1,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

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