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

Обратная матрица. Метод Гаусса—Жордана - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Программа проверяет корректность ввода данных http://www.cyberforum.ru/cpp-beginners/thread925063.html
1) Пользователь вводит телефон и электронную почту. Программа проверяет корректность ввода данных. (Работа со строками и массивами.) Просто дайте подсказку как реализовать, я сам хочу сделать.
C++ Некорректно отображается содержимое файла Написал программку для чтения файла, файл считывается, но содержимое его отображается некорректно, например так: 0014FC. Подскажите метод корректного вывода. #include<iostream> #include<conio.h> #include<fstream> using namespace std; int main() { setlocale(0,""); http://www.cyberforum.ru/cpp-beginners/thread925062.html
Алгоритмы обработки изображений и видео C++
Привет всем! Я только только начинаю изучать программирование - рекомендовали начать немного с турбо паскаля, а потом перейти на С - как вы считаете с какого С языка начать изучать программирование? И конкретный вопрос - меня интересуют методы построения алгоритмов для обработки видео (автоматический захват объекта и контроль его движения - то есть скорость, и прочие параметры) Как я понимаю...
Битовые операции C++
Всем привет! Помогите решить интересную задачу! Нужно ниже указный код переписать без условных операторов используя только битовые операции т.е & | ^ ~ << >>. Дополнительных переменных добавлять нельзя, так же нельзя использовать массивы. /* значения a,value1,result1,result2 задаются пользователем */ if ( a == value1) { b = result1; } else { b = result2;
C++ Быстрый ввод и вывод http://www.cyberforum.ru/cpp-beginners/thread924986.html
Добрый день. Прошу прощения за нубский вопрос, но все-таки... Хотелось бы узнать у гуру, какие операторы обеспечивают самый быстрой ввод и вывод в файл.
C++ Возможно ли работать с _CrtDumpMemoryLeaks() в MinGW? _CrtDumpMemoryLeaks() может работать в mingw или это только для студии? подробнее

Показать сообщение отдельно
Helo
4 / 4 / 0
Регистрация: 04.07.2013
Сообщений: 52

Обратная матрица. Метод Гаусса—Жордана - C++

18.07.2013, 12:45. Просмотров 4219. Ответов 2
Метки (Все метки)

Здравствуйте. Пишу программку вычисления матриц и вот эта функция ( см. код ) компилируется и работает без ошибок, но считает не правильно. Кто хорошо знает математику и программирование подскажите, что я делаю не так?
Ссылка на вики обратная матрица http://ru.wikipedia.org/wiki/%D0%9E%...B8%D1%86%D0%B0
Код проблемной функции. Язык 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
30
31
32
33
34
35
36
37
38
39
40
41
42
void Invers_Array ( double ** & Matrix, const short int & size )
{
    double a, b, sum = 0;
    double ** Invers_Matrix = new double * [ size ];     /* Единичная матрица */
    for ( int i = 0; i < size; i ++ )
    {
        Invers_Matrix [i] = new double [ size ];
        for ( int j = 0; j < size; j ++ )
            Invers_Matrix [i][j] = 0;
            Invers_Matrix [i][i] = 1;
    }
    for ( int i = 0; i < size; i ++ )     /* Приведём матрицу к треугольной при помощи алгоритма Гаусса */
    {
        a = Matrix [i][i];
        for ( int j = i + 1; j < size; j ++ )
        {
            b = Matrix [j][i];
            for ( int k = 0; k < size; k ++ )
            {
                Matrix [j][k] = Matrix [i][k] * b - Matrix [j][k] * a;
                Invers_Matrix [j][k]= Invers_Matrix [i][k] * b - Invers_Matrix [j][k] * a;
            }
        }
    }
    for ( int i = 0; i < size; i ++ )     /* Обратный ход вычисления элементов обратной матрицы */
    {
        for ( int j = size - 1; j >= 0; j -- )
        {
            for ( int k = size - 1; k > j; k -- )
                sum += Matrix [j][k] * Invers_Matrix [k][i];
                if ( Matrix [j][j] == 0 )
                {
                    for ( int i = 0; i < size; i ++ )
                        delete [] Invers_Matrix [i];
                        delete [] Invers_Matrix;
                }
                Invers_Matrix [j][i] = ( Invers_Matrix [j][i] - sum ) / Matrix [j][j];
        }
    }
    printf ( "\n%s", " Обратная матрица \n\n" );
    Output_Array ( Invers_Matrix, size );
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru