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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
KeMesh
0 / 0 / 0
Регистрация: 11.06.2012
Сообщений: 7
#1

Появляется -1.#IND в результатах - C++

11.06.2012, 19:53. Просмотров 925. Ответов 5
Метки нет (Все метки)

Доброго времени суток.

Извеняюсь за глупые (возможно) вопросы зарание.

Программа на C++. вычисляет обратную матрицу методом жордана-гаусса. Размер матрицы задается пользователем.

Проблема: при введении размера матрицы от 2х2 до 4х4 все вычисления происходят как положенно. При вычислении матрицы 5х5 и более выдает все результаты как -1.#IND

Код программы.

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
#include <iostream>
 
void inversion(double **A, int N)
{
    double temp;
 
    double **E = new double *[N];
 
    for (int i = 0; i < N; i++)
        E[i] = new double [N];
 
    for (int i = 0; i < N; i++)
        for (int j = 0; j < N; j++)
        {
            E[i][j] = 0.0;
 
            if (i == j)
                E[i][j] = 1.0;
        }
 
    for (int k = 0; k < N; k++)
    {
        temp = A[k][k];
 
        for (int j = 0; j < N; j++)
        {
            A[k][j] /= temp;
            E[k][j] /= temp;
        }
 
        for (int i = k + 1; i < N; i++)
        {
            temp = A[i][k];
 
            for (int j = 0; j < N; j++)
            {
                A[i][j] -= A[k][j] * temp;
                E[i][j] -= E[k][j] * temp;
            }
        }
    }
 
    for (int k = N - 1; k > 0; k--)
    {
        for (int i = k - 1; i >= 0; i--)
        {
            temp = A[i][k];
 
            for (int j = 0; j < N; j++)
            {
                A[i][j] -= A[k][j] * temp;
                E[i][j] -= E[k][j] * temp;
            }
        }
    }
 
    for (int i = 0; i < N; i++)
        for (int j = 0; j < N; j++)
            A[i][j] = E[i][j];
 
    for (int i = 0; i < N; i++)
        delete [] E[i];
 
    delete [] E;
}
 
int main()
{
    int N;
 
    std::cout << "Enter N: ";
    std::cin >> N;
 
    double **matrix = new double *[N];
 
    for (int i = 0; i < N; i++)
        matrix[i] = new double [N];
 
    for (int i = 0; i < N; i++)
        for (int j = 0; j < N; j++)
        {
            std::cout << "Enter matrix[" << i << "][" << j << "] = ";
            std::cin >> matrix[i][j];
        }
 
    inversion(matrix, N);
 
    for (int i = 0; i < N; i++)
    {
        for (int j = 0; j < N; j++)
            std::cout << matrix[i][j] << "  ";
 
        std::cout << std::endl;
    }
 
    for (int i = 0; i < N; i++)
        delete [] matrix[i];
 
    delete [] matrix;
 
    std::cin.get();
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.06.2012, 19:53     Появляется -1.#IND в результатах
Посмотрите здесь:

-1.#IND при возвращении значения функции C++
C++ Выбивает 1.#IND
C++ Символ -1.#IND
C++ ошибка -1#IND
Результат -1.#IND C++
Задачка с рядами Тейлора выводит -1.#IND C++
C++ Подскажите что это за символы 1#IND
Убрать -1#ind в программе C++
Код выдает непонятный результат -1.#IND C++
Почему выдает -1.#IND C++
C++ Интегрирования трапециями. Ошибка -nan(ind)
-1.#IND ошибка C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
11.06.2012, 20:02     Появляется -1.#IND в результатах #2
судя по результату у тебя где-то деление на ноль вещественного числа
KeMesh
0 / 0 / 0
Регистрация: 11.06.2012
Сообщений: 7
11.06.2012, 21:21  [ТС]     Появляется -1.#IND в результатах #3
Единственное деление есть в этом фрагменте

C++
1
2
3
4
5
6
7
8
9
    for (int k = 0; k < N; k++)
    {
        temp = A[k][k];
 
        for (int j = 0; j < N; j++)
        {
            A[k][j] /= temp;
            E[k][j] /= temp;
        }
но вроде не должно... да и числа ввожу единицы.

Добавлено через 1 час 9 минут
подскажите пожалуйста. сам точно не решу, ибо с++ ток начали изучать.
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
11.06.2012, 21:34     Появляется -1.#IND в результатах #4
Цитата Сообщение от KeMesh Посмотреть сообщение
подскажите пожалуйста. сам точно не решу, ибо с++ ток начали изучать.
это не вопрос с++ - это вопрос отладки
при таком вводе
5
1 2 3 4 5
6 7 8 9 1
1 2 3 5 3
2 5 7 3 5
3 4 7 8 9
получается
temp[0,0] = 1
temp[1,1] = -5
temp[2,2] = 0
temp[3,3] = inf
temp[4,4] = -nan
-nan -nan -nan -nan -nan
-nan -nan -nan -nan -nan
-nan -nan -nan -nan -nan
-nan -nan -nan -nan -nan
-nan -nan -nan -nan -nan
очевидно, что в алгоритме есть деление на ноль
ЗЫ: надеюсь ты числа не вручную каждый раз вводишь?
KeMesh
0 / 0 / 0
Регистрация: 11.06.2012
Сообщений: 7
11.06.2012, 21:40  [ТС]     Появляется -1.#IND в результатах #5
В ручную конечно. код как есть) просто с++ ток начали изучать и на вечерке еще. Спасибо буду пытаться ввести проверку на принадлежность нулю.

З.ы. аватарка зачетная)
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
11.06.2012, 21:42     Появляется -1.#IND в результатах #6
Цитата Сообщение от KeMesh Посмотреть сообщение
В ручную конечно. код как есть)
ну можно же сделать нечто вроде
cat task.txt | ./a.out
в винде в том числе
Yandex
Объявления
11.06.2012, 21:42     Появляется -1.#IND в результатах
Ответ Создать тему
Опции темы

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