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

СЛАУ методом Крамера - C++

Восстановить пароль Регистрация
 
Kindaso
0 / 0 / 0
Регистрация: 01.10.2016
Сообщений: 3
01.10.2016, 12:40     СЛАУ методом Крамера #1
Здравствуйте! Пишу программу для решения СЛАУ методом Крамера (максимум 4 системы за раз).


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
#include<iostream>
#include<conio.h>
#include<stdlib.h>
using namespace std;
 
 
 
int main()
{
system("cls");
    float *A, *X;
    int k, i, j, n;
    cout << "Vvedite kolichestvo sistem uravneniy" << endl;
    cin >> n;
 
    A = new float[n * 3 * 4];
    X = new float[n*4];
    for (k = 0; k < n; k++)
    {
        cout << "Vedite koeffitsienti i svobodnie chleni sistemi nomer " << k + 1 << endl;
        for (i = 0; i < 3; i++)
            for (j = 0; j < 4; j++)
            {
            
            
                if (j != (3))
                {
                    cout << "\nVvedite x[" << i + 1 << "] [" << j + 1 << "] ";
                }
                else
                {
                    cout << "\nVvedite svobodniy chlen ";
                }
                cin >> *(A + k * 3 + i * 4 + j);
            }
        
    
    
        *(X + k * 4 + 0) = *(A + k * 3 + 0 * 4 + 0) * *(A + k * 3 + 1 * 4 + 1) * *(A + k * 3 + 2 * 4 + 2) + *(A + k * 3 + 0 * 4 + 1) * *(A + k * 3 + 1 * 4 + 2) * *(A + k * 3 + 2 * 4 + 0) + *(A + k * 3 + 0 * 4 + 2) * *(A + k * 3 + 1 * 4 + 0) * *(A + k * 3 + 2 * 4 + 1) - *(A + k * 3 + 0 * 4 + 0) * *(A + k * 3 + 1 * 4 + 2) * *(A + k * 2 + 2 * 4 + 1) - *(A + k * 3 + 0 * 4 + 1) * *(A + k * 3 + 1 * 4 + 0) * *(A + k * 3 + 2 * 4 + 2) - *(A + k * 3 + 0 * 4 + 2) * *(A + k * 3 + 1 * 4 + 1) * *(A + k * 3 + 2 * 4 + 0);
 
        *(X + k * 4 + 1) = *(A + k * 3 + 0 * 4 + 3) * *(A + k * 3 + 1 * 4 + 1) * *(A + k * 3 + 2 * 4 + 2) + *(A + k * 3 + 0 * 4 + 1) * *(A + k * 3 + 1 * 4 + 2) * *(A + k * 3 + 2 * 4 + 3) + *(A + k * 3 + 0 * 4 + 2) * *(A + k * 3 + 1 * 4 + 3) * *(A + k * 3 + 2 * 4 + 1) - *(A + k * 3 + 0 * 4 + 3) * *(A + k * 3 + 1 * 4 + 2) * *(A + k * 2 + 2 * 4 + 1) - *(A + k * 3 + 0 * 4 + 1) * *(A + k * 3 + 1 * 4 + 3) * *(A + k * 3 + 2 * 4 + 2) - *(A + k * 3 + 0 * 4 + 2) * *(A + k * 3 + 1 * 4 + 1) * *(A + k * 3 + 2 * 4 + 3);
 
        *(X + k * 4 + 2) = *(A + k * 3 + 0 * 4 + 0) * *(A + k * 3 + 1 * 4 + 3) * *(A + k * 3 + 2 * 4 + 2) + *(A + k * 3 + 0 * 4 + 3) * *(A + k * 3 + 1 * 4 + 2) * *(A + k * 3 + 2 * 4 + 0) + *(A + k * 3 + 0 * 4 + 2) * *(A + k * 3 + 1 * 4 + 0) * *(A + k * 3 + 2 * 4 + 3) - *(A + k * 3 + 0 * 4 + 0) * *(A + k * 3 + 1 * 4 + 2) * *(A + k * 2 + 2 * 4 + 3) - *(A + k * 3 + 0 * 4 + 3) * *(A + k * 3 + 1 * 4 + 0) * *(A + k * 3 + 2 * 4 + 2) - *(A + k * 3 + 0 * 4 + 2) * *(A + k * 3 + 1 * 4 + 3) * *(A + k * 3 + 2 * 4 + 0);
 
        *(X + k * 4 + 3) = *(A + k * 3 + 0 * 4 + 0) * *(A + k * 3 + 1 * 4 + 1) * *(A + k * 3 + 2 * 4 + 3) + *(A + k * 3 + 0 * 4 + 1) * *(A + k * 3 + 1 * 4 + 3) * *(A + k * 3 + 2 * 4 + 0) + *(A + k * 3 + 0 * 4 + 3) * *(A + k * 3 + 1 * 4 + 0) * *(A + k * 3 + 2 * 4 + 1) - *(A + k * 3 + 0 * 4 + 0) * *(A + k * 3 + 1 * 4 + 3) * *(A + k * 2 + 2 * 4 + 1) - *(A + k * 3 + 0 * 4 + 1) * *(A + k * 3 + 1 * 4 + 0) * *(A + k * 3 + 2 * 4 + 3) - *(A + k * 3 + 0 * 4 + 3) * *(A + k * 3 + 1 * 4 + 1) * *(A + k * 3 + 2 * 4 + 0);
 
}
 
        for (k = 0; k < n; k++)
        {
            cout<<"\nSistema "<<k+1<<endl;
            for (j = 0; j <4;j++)
                cout << *(X + k * 4 + j) << "   ";
            cout << endl;
        }  
 
 
    delete A;
    delete X;
    getch();
    return 0;
}

Однако при вводе больше одной системы, определители считаются правильно только для первой. Никак не пойму в чём причина.Помогите пожалуйста.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.10.2016, 12:40     СЛАУ методом Крамера
Посмотрите здесь:

Решание СЛАУ методом Гаусса в С++ C++
C++ Написать решение систем линейных уравнений методом Крамера
Решение СЛАУ методом Зейделя C++
C++ Решение СЛАУ методом Крамера
Решить систему уравнений методом Крамера C++
C++ задача методом крамера (как проверить вход данные с++)
C++ решение матрицы методом крамера
C++ СЛАУ методом итераций
СЛАУ методом градиентного спуска C++
C++ Вычисление корней системы уравнений методом Крамера
СЛАУ методом Гаусса C++
Утечка памяти (решение СЛАУ методом Крамера, матрицы, malloc) C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
nmcf
4441 / 3779 / 1278
Регистрация: 14.04.2014
Сообщений: 14,872
01.10.2016, 13:44     СЛАУ методом Крамера #2
Матрица 3x3 и их 4 штуки? А зачем так?
Kindaso
0 / 0 / 0
Регистрация: 01.10.2016
Сообщений: 3
01.10.2016, 13:48  [ТС]     СЛАУ методом Крамера #3
Условия лабы
Yandex
Объявления
01.10.2016, 13:48     СЛАУ методом Крамера
Ответ Создать тему
Опции темы

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