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

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

Восстановить пароль Регистрация
 
oleg@tor1
 Аватар для oleg@tor1
32 / 17 / 2
Регистрация: 05.09.2011
Сообщений: 152
18.11.2013, 13:22     Не работает транспорирование матрицы #1
Написал небольшой класс "матрица", не получается одно - транспорировать, хотя алгоритм ясен и понятен. Что-то я упустил в коде. Матрица выводится неизмененная. Как-то неверно я задаю ссылки на объект, кажется.
Класс:
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
 
namespace Class_Matrix
{
  class Matrix
    {        
        int N;                // Размерность матрицы.
        double[,] marix_1;    // 2x Массив (x,x)
        double t = 0;         // Эта перем. будет исп. в циклах.        
 
        public double this[int i, int j]   // Индексатор типа int в классе. Индексаторы позволяют индексировать экземпляры класса или структуры так же, как массивы. Индексаторы напоминают свойства, но их методы доступа принимают параметры.
        {
            get { return marix_1[i,j];}    // Возвр. зн-е, наход. по указ. индексу.
            set { marix_1[i, j] = value; } // Установка значения, которое определяет индекс.
        }
 
 
        public Matrix(int N) // Конструктор задаёт начальные параметры для матрицы.
        {           
            this.N = N;
            this.marix_1 = new double[N,N];    // Задали матрицу (двумерный массив).
        }
 
 
        public void CreateMatrix(int randSeed) // Создаём матрицу. randSeed задаёт сл.число.
        {          
            Random rand = new Random(randSeed);
            for (int i = 0; i < N; ++i) 
            {
                for (int j = 0; j < N; ++j)
                 {
                     double randNum = rand.Next(0, 100);
                     marix_1[i, j] = randNum; 
                 }
            }
        }
 
        public void WriteMatrix()              // Отображаем матрицу.
        {
            for (int i = 0; i < N; ++i)  
            {
                for (int j = 0; j < N; ++j)
                {
                    Console.Write("{0}\t",marix_1[i, j]); // Спецификатор отобр. первый параметр + таблица.
                }
                Console.WriteLine();
            }
        }
 
        public static Matrix operator +(Matrix A, Matrix B)// Перегружаем оператор +.
        {
            Matrix C = new Matrix(A.N);                    // Новая матрица для результата.
           
            for (int i = 0; i < A.N; ++i)
            {
              for (int j = 0; j < A.N; ++j)
              {
                  C[i, j] = A[i, j] + B[i, j];
              }
            }
            Console.Write("{0} \n", "Результат сложения двух матриц:");
            return C;   // Оператор возвращает треб. значение.             
        }
 
        public static Matrix operator -(Matrix A, Matrix B)// Перегружаем оператор -.
        {
            Matrix R = new Matrix(A.N);                    // Новая матрица для результата.
 
            for (int i = 0; i < A.N; ++i)
            {
                for (int j = 0; j < A.N; ++j)
                {
                    R[i, j] = A[i, j] - B[i, j];
                }
            }
            Console.Write("{0} \n", "Результат вычитания двух матриц:");
            return R;   // Оператор возвращает треб. значение.             
        }
 
        public static Matrix operator *(Matrix A, Matrix B)// Перегружаем оператор *.
        {
            Matrix U = new Matrix(A.N);                    // Новая матрица для результата.
 
            for (int i = 0; i < A.N; ++i)
            {
                for (int j = 0; j < A.N; ++j)
                {
                    for (int m = 0; m < A.N; ++m)
                    {
                        U[i, j] += A[i, m] * B[m, j];
                    }
                }
            }
            Console.Write("{0} \n", "Результат умножения двух матриц:");
            return U;   // Оператор возвращает треб. значение.           
        }
 
 
        // Транспорируем матрицу.
        public void Trans ()          
        {   
                       
            double tmp;
            
                         
            for (int i = 0; i < N; i++)
            {
                for (int j = 0; j < N; j++)
                {
                    tmp = marix_1[i, j];
                    marix_1[i, j] = marix_1[j, i];
                    marix_1[j, i] = tmp;
                }
            }            
        }
 
    }
}
Прога:
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Class_Matrix;
 
namespace Class_Matrix
{
    class Program
    {
        static void Main(string[] args)
        {
            const int size = 3;
            
            Matrix Matrix1 = new Matrix(size);
            Matrix1.CreateMatrix(88);
            Matrix1.WriteMatrix();
 
            Console.WriteLine();
 
            Matrix Matrix2 = new Matrix(size);
            Matrix2.CreateMatrix(77);
            Matrix2.WriteMatrix();
 
            Console.WriteLine();
 
            Matrix Matrix3 = new Matrix(size);
            Matrix3 = Matrix1 + Matrix2;
            Matrix3.WriteMatrix();
 
            Console.WriteLine();
 
            Matrix Matrix4 = new Matrix(size);
            Matrix4 = Matrix1 - Matrix2;
            Matrix4.WriteMatrix();
 
            Console.WriteLine();
 
            Matrix Matrix5 = new Matrix(size);
            Matrix5 = Matrix1 * Matrix2;
            Matrix5.WriteMatrix();
 
            Console.WriteLine();
            // Транспорируем.
            Matrix5.CreateMatrix(55);
            Matrix5.WriteMatrix();
            Matrix5.Trans();
            Matrix5.WriteMatrix();
 
            //Matrix Matrix6 = new Matrix(size);
            //Matrix6.CreateMatrix(23);
            //Matrix6.WriteMatrix();
            //Matrix6.Trans();
            //Matrix6.WriteMatrix();
 
            Console.WriteLine();
            
        } 
 
    }
    
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.11.2013, 13:22     Не работает транспорирование матрицы
Посмотрите здесь:

C++ То работает, то не работает. Массив из случайных вещественных чисел
C++ Дан алгоритм нахождения обратной матрицы. По нему хочу написать код. Но непонятно по какому методу он работает.
C++ Программа сортировки матрицы, работает только для квадратных
Не корректно работает программа (Упорядочить элементы матрицы) C++
Русификация.Работает-супер! Обьяснитте, как это работает? C++
C++ setprecision() не работает, или работает не так как нужно
C++ Подсчитать число отрицательных элементов матрицы. Почему работает не правильно?
Упорядочить по уменьшению побочную диагональ матрицы, не работает код C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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