Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 16.04.2015
Сообщений: 47
1

Метод Гаусса

17.11.2016, 22:38. Показов 426. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Приветствую, подскажите в чем ошибка.
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
int gauss(int n, double **A, double **&E)
{
    //создание единичной матрицы
    for (int i = 0; i < n; i++)
        for (int j = 0; j < n; j++)
        {
            if (i == j)
                E[i][j] = 1;
            else
                E[i][j] = 0;
        }
 
    //приведение к верхнетреугольному виду и нахождение определителя
    for (int step = 0; step<n - 1; step++)
        for (int row = step + 1; row < n; row++)
        {
            double coeff = -A[row][step] / A[step][step];
            for (int col = step; col < n; col++)
            {
                A[row][col] += A[step][col] * coeff;
                E[row][col] += E[step][col] * coeff;
            }
        }
 
    double e;
    for (int i = 0; i < n; i++)
        det *= A[i][i];
    cout << "Определитель А = " << det << endl << endl;
 
    //получаем единицы в главной диагонали
    if (det != 0)
    {
        
        for (int k = 0; k < n; k++)
        {
            double t = A[k][k];
            for (int j = 0; j < n; j++)
            {
                A[k][j] /= t;
                E[k][j] /= t;
            }
        }
                
        for (int step = n-1; step > 0; step--)
            for (int row = step - 1; row >=0; row--)
            {
                double coeff = -A[row][step];
                for (int col = n - 1; col >= 0; col--)
                {
                    A[row][col] += A[step][col] * coeff;
                    E[row][col] += E[step][col] * coeff;
                }
            }
        cout << "Обратная матрица А" << endl;
        print_matrix(n, n, E);
    }
 
 
    return 1;
}
Приведение к верхнетреугольному виду и нахождение определителя работает нормально, проблемы начинаются при получении нулей ниже глав. диагонали. Никак не могу понять, в чем причина некорректных значений.

Добавлено через 1 час 0 минут
Пробовал по разному делать - та же проблема - не все значения корректны.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.11.2016, 22:38
Ответы с готовыми решениями:

СЛАУ. Метод обратной матрицы, метод Гаусса, метод Крамера, метод Зейделя
Помогите ребят. Не могу построить алгоритмы для этих методов Язык C++

Метод Гаусса в С++
Подскажите please, как запустить эту программу, через C++??? Решение системы линейных уравнений...

метод Гаусса
Помогите пожалуйста написать программу на С++ Задана система линейного уравнения:MA*X=B. Для...

метод Гаусса
дана система линейных уравнений, в графическом режиме надо написать программу. Не понимаю как,...

0
17.11.2016, 22:38
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.11.2016, 22:38
Помогаю со студенческими работами здесь

Метод Гаусса
Суть в том что бы СЛАУ методом Гаусс с последовательным исключениям неизвестных.Вот система:...

метод гаусса
Помогите,пожалуйста Преподаватель попросил расписать программу по блокам #include &quot;stdio.h&quot;...

Метод Гаусса
Здравствуйте, у меня такая проблема. Мне нужно написать программу, которая решает СЛАУ методом...

Метод Гаусса
Метод Гаусса объясните, пожалуйста, как работают строки: float **A = new float *; for...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru