0 / 0 / 1
Регистрация: 09.05.2016
Сообщений: 7
1

Обратная матрица

12.05.2016, 17:42. Показов 2901. Ответов 2
Метки нет (Все метки)

Люди добрые! Прошу у вас помощи, для курсовой осталось сделать последнее задание, нужно найти обратную матрицу для заданной. Может есть у кого готовые алгоритмы?.. перерыл достаточное количество сайтов и форумов, но что то нормального, работающего кода так и не нашел ...
__________________
Помощь в написании контрольных, курсовых и дипломных работ здесь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.05.2016, 17:42
Ответы с готовыми решениями:

Обратная матрица
Блин народ киньте метод. Я уже не знаю почему мой метод не вычисляет(((.

Обратная матрица
Добрый день! Подскажите пожалуйста код нахождения обратной матрицы n на n.

Обратная матрица
1 элемент считает а дальше нули(проверял по калькулятору 1 элемент сходиться) вот код using...

Обратная матрица
помогите, пожалуйста как найти обратную матрицу?

2
184 / 183 / 96
Регистрация: 30.04.2016
Сообщений: 478
12.05.2016, 19:30 2
Смотрел вложение в последнем посте тут Обратная матрица?
1
0 / 0 / 1
Регистрация: 09.05.2016
Сообщений: 7
13.05.2016, 09:11  [ТС] 3
Лучший ответ Сообщение было отмечено chr0m1um как решение

Решение

Посмотрел вложение, это в целом то, что мне нужно. Но где тут именно метод, совершающий обращение матрицы? Попытался выцепить кусок кода для себя, но что-то не получилось, мозги не очень соображают.. не подскажите?
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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
 
namespace WindowsFormsApplication2
{
    public partial class Form1 : Form
    {   // ВНИМЕНИЕ. Данная программа педназначена только для квадратных матриц, точно имеющих решение, с невыражденой главнй диаганалью и т.д и т.п.
        //Программа НЕ имеет обработчиков ошибок.// это число применяются для задания матрицы. многим методам программы необходимо знать размер матрицы поэтому
        // я его вынес " на верх". а ещё потому, что неумею выводить несколько параметров. 
        //  [url]https://www.cyberforum.ru/csharp-beginners/thread868040.html[/url] 
        //Если не понравилось то можно посматреть тут [url]http://msdn.microsoft.com/ru-ru/magazine/jj863137.aspx[/url]
        // Данный код, есть переделка отсюда :[url]http://www.********************/showthread.php?t=133673[/url]
        /*размеры матриц*/
        static int razmer;
        public Form1()
        {
            InitializeComponent();
        }
 
        private void Form1_Load(object sender, EventArgs e)
        {
        }
 
        private void AddColumns(int m, DataGridView dgw)
        {
            //добавляет n столбцов в элемент управления dgw
            //Заполнение DGView столбцами
            DataGridViewColumn column;
            for (int i = 0; i < m; i++)
            {
                column = new DataGridViewTextBoxColumn();
                column.DataPropertyName = "Столбец" + i.ToString();
                column.Name = "Столбец" + i.ToString();
                dgw.Columns.Add(column);
            }
        }
        private void AddRows(int k, DataGridView dgw)
        {
            //добавляет m строк в элемент управления dgw            
            //Заполнение DGView строками
            for (int i = 0; i < k; i++)
            {
                dgw.Rows.Add();
                dgw.Rows[i].HeaderCell.Value
                    = "row" + i.ToString();
            }
        }
        // метод инициализирует( бранирует или выделяет) место под новые строки и столбцы; создаёт 2-х мерный квадратный массив!
        public double[,] MatrixCreate1(int rowscols)
        {
           
            if (rowscols != 0)
            {
                /*Очищаем матрицу */
                dataGridView1.Columns.Clear();
                dataGridView2.Columns.Clear();
                /*Заполнение DGView столбцами */
                AddColumns(rowscols, dataGridView1);
                AddColumns(rowscols, dataGridView2);
                /*Заполнение DGView строками*/
                AddRows(rowscols, dataGridView1);
                AddRows(rowscols, dataGridView2);
                Random rnd = new Random();
                int g;
                double[,] hhh = new double[rowscols,rowscols];
               /* {
                {5,8,8},
                {5,10,3},
                {7,9,19}
                };*/
                //проверочная матрица
                 for (int i = 0; i < rowscols; ++i)
                   {   
                       for (int j = 0; j < rowscols; ++j)
                       {   
                           g=rnd.Next(10, 500);
                           hhh[i,j]=g;
                           dataGridView1.Rows[i].Cells[j].Value = hhh[i,j];                     
                       }
                   } 
                   return hhh;
               }
            return null;
        }
        static double[,] One1(double[,] hhh, int h)
        { //'единичная матрица
            //    h = 3; //активаровать для проверки. результат найдите тут: [url]http://matrixcalc.org/[/url]
            
            double[,] ggg = new double[h, h];// единичная матрица           
            //   Dim A_edin(k + 1, k + 1) As Double 'затем она перейдёт в обратную
            for (int i = 0; i < h; )
            {
                for (int j = 0; j < h; )
                {
                    if (i == j)
                    { ggg[i, j] = 1; }
                    else
                    { ggg[i, j] = 0; }
                    j++;
                }
                i++;
            }
            //  'единичная матрица
            //'обратная матрица
            double arg;
            int i1;
            //  Dim arg As Double
            //   Dim i1 As Integer
 
            for (int j = 0; j < h; )
            {
                for (int i = 0; i < h; )
                {
                    if (i == j)
                    { goto k; }
                    arg = hhh[i, j] / hhh[j, j];
                    for (i1 = 0; i1 < h; )
                    {
 
                        hhh[i, i1] = hhh[i, i1] - hhh[j, i1] * arg;
                        ggg[i, i1] = ggg[i, i1] - ggg[j, i1] * arg;
                        i1++;
                    }
                k:
                    i++;
                }
                j++;
            }
 
            for (int j = 0; j < h; )
            {
                for (int i = 0; i < h; )
                {
                    double arg_2;
                    if (i == j)
                    {
                        arg_2 = hhh[i, j];
                        for (i1 = 0; i1 < h; )
                        {
                            hhh[i, i1] = hhh[i, i1] / arg_2;
                            ggg[i, i1] = ggg[i, i1] / arg_2;
                            i1++;
                        }
 
 
                    }
                    i++;
                }
                j++;
            }
            return ggg;
        }   
        // Метод для распечатки матрицы в грид1
        public void Print1(double[,] matrix, int rowscols)
        {
            //double[][] result;
            for (int i = 0; i < rowscols; ++i) // Копирование значений
                for (int j = 0; j < rowscols; ++j)
                {
 
                    dataGridView1.Rows[i].Cells[j].Value = matrix[i, j];
                }
 
        }
        // метод для распечаткт в грид2
        public void Print2(double[,] matrix, int rowscols)
        {
            //double[][] result;
            for (int i = 0; i < rowscols; ++i) // Копирование значений
                for (int j = 0; j < rowscols; ++j)
                {
 
                    dataGridView2.Rows[i].Cells[j].Value = matrix[i, j];
                }
 
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            razmer = Convert.ToInt32(textBox1.Text);
            double[,] jjj = MatrixCreate1(razmer);           
            double[,] kkk = One1(jjj,razmer);
            Print1(jjj, razmer);
            Print2(kkk,razmer);
           
        }
        private void button2_Click(object sender, EventArgs e)
        {
            
        }
       
     
        private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
        {
        
        }
 
        private void dataGridView1_CellContentClick_1(object sender, DataGridViewCellEventArgs e)
        {
 
        }
    }
}
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.05.2016, 09:11

обратная матрица
помогите написать опрограмму обратной матрицы!!! плиз!!!! никак не получается

Обратная матрица
Нужно написать обратную матрицу, начал искать определитель, но появилась ошибка и не могу ее...

Жордановы исключения-обратная матрица
Вот написала код для нахождения обратной матрицы способом Жордановых исключений. РАБОТАЕТ, но как...

Обратная матрица методом Гаусса, исправить код
Помогите пожалуйста..всю ночь просидел не могу найти ошибку,возвращает NaN- понимаю что идет...


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

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

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