Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 14, средняя оценка - 4.93
ideaworks
1 / 1 / 0
Регистрация: 12.06.2012
Сообщений: 15
#1

Программа для решения слау методом главных элементов для всеразмерной матрицы - C++

02.10.2012, 22:02. Просмотров 2138. Ответов 5
Метки нет (Все метки)

Вот написал программу для решения слау методом главных элементов для всеразмерной матрицы, вобщем вот в чём проблема при получении новой матрицы нижние иксы неправильно находит, а b правильно (во вложеннии чуть понятней объяснил наверно)

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
#include <iostream>
#include <stdio.h>
#include <cmath>
 
using namespace std;
 
int main()
{
    int i,j,t=0,n;
    cout<<"razmer: ";
    cin>>n;
    float max,b[n+1],a[n][n+1],m[n-1];
 
   cout<<"vvedite matricu: \n";
    for(i=0;i<n;i++)
    {for(j=0;j<n+1;j++)
    cin>>a[i][j];}
 
    //выводим начальную матрицу оформленно
    cout<<"\nInput matrica:\n";
    for(i=0;i<n;i++)
    {for(j=0;j<n+1;j++)
    cout<<a[i][j]<<" "; cout<<"\n";}
 
    while(n>1)
    {
        for(i=0;i<20;i++)
        {cout<<"-";}
    max=a[0][0];
    //максимальный элемент в первом столбце
    for(i=0;i<n;i++)
    {if(max<fabs(a[i][0])) {max=a[i][0]; t=i;}}
    cout<<"\nMax element: "<<max<<endl;
    //переставляем строки, если максимальный элемент не в первой строке
    if (max!=a[0][0])
    {for(j=0;j<n+1;j++)
    {b[j]=a[t][j];
    a[t][j]=a[0][j];
    a[0][j]=b[j];}
 
    cout<<"\nPerestavili stroki:"<<endl;
    for(i=0;i<n;i++)
    {for(j=0;j<n+1;j++)
    cout<<a[i][j]<<" "; cout<<"\n";}}
 
    //вычисляем множители
    cout<<"\nMnozhitels: ";
    for(i=0;i<n-1;i++)
    {m[i]=-(a[i+1][0]/a[0][0]);
    cout<<"m["<<i+1<<"]="<<m[i]<<" ";}
    cout<<"\na[2][1]="<<a[2][1]<<endl;
    cout<<"Vyvod "<<a[2][1]+a[0][1]*m[1];
 
    //формируем новую матрицу
    for(i=0;i<n-1;i++)
    {for(j=0;j<n;j++)
    a[i][j]=a[i+1][j+1]+a[0][j+1]*m[i];}
    //выводим оформленно
    cout<<"\n\nNew matrix:"<<endl;
    for(i=0;i<n-1;i++)
    {for(j=0;j<n;j++)
    cout<<a[i][j]<<" "; cout<<"\n";}
 
    n--;
    }
    return 0;
}
0
Миниатюры
Программа для решения слау методом главных элементов для всеразмерной матрицы  
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.10.2012, 22:02
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Программа для решения слау методом главных элементов для всеразмерной матрицы (C++):

Разработать программу для решения СЛАУ методом Гаусса. - C++
Разработать программу для решения СЛАУ методом Гаусса. вот заданный массив 7x1-x2+2x3+x4+x5=7 2x1+5x2-x3-x5=3 ...

Написание программы для решения СЛАУ методом Зейделя - C++
#include &quot;stdafx.h&quot; #include &lt;stdio.h&gt; #include &lt;iostream&gt; #include &lt;cmath&gt; #include &lt;conio.h&gt; using namespace std; const...

Программа для решения СЛАУ - C++
Здравствуйте,в общем, моя программа решает СЛАУ матричным методом, на основе библиотеки Matrixclass, программа вылетает из-за привышения...

Помогите написать программу для решения слау методом Гаусса - C++
Осталось как обычно пару дней до сдачи курсовой, а она еще не готова! Помогите пожалуйста. Вот код, который чуть-чуть работает Главная...

Алгоритм написания для решения СЛАУ методом простых итераций - C++
Прошу помощи в написании программы для решения СЛАУ методом итераций. Нет, я не прошу писать код за меня, я прошу вашей помощи, чтобы...

Кто сможет? Написать функцию для решения СЛАУ методом Гаусса - C++
Кто может написать функцию для решения СЛАУ методом Гаусса используя базовые знания.

5
ideaworks
1 / 1 / 0
Регистрация: 12.06.2012
Сообщений: 15
02.10.2012, 22:19  [ТС] #2
Вроде алгоритм правильный, однако неправильно решает нижние иксы, "b" из этой же строки правильно находит, не знаю что уже делать...
P.S. Корни не нахожу еще
0
Thinker
Эксперт С++
4229 / 2203 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
02.10.2012, 22:21 #3
Вникать не стал, но бросается в глаза индексация по j в цикле
C++
1
2
3
for(i=0;i<n-1;i++)
    {for(j=0;j<n;j++)
    a[i][j]=a[i+1][j+1]+a[0][j+1]*m[i];}
хотя... матрица a у вас с запасом создана
0
ideaworks
1 / 1 / 0
Регистрация: 12.06.2012
Сообщений: 15
03.10.2012, 09:18  [ТС] #4
Не пасибо, я справился сам
0
silent_1991
Эксперт С++
4989 / 3046 / 149
Регистрация: 11.11.2009
Сообщений: 7,028
Завершенные тесты: 1
07.10.2012, 16:52 #5
ideaworks, раз справились сами - выложите найденное вами решение сюда, оно может быть интересно не только вам.
0
ideaworks
1 / 1 / 0
Регистрация: 12.06.2012
Сообщений: 15
08.10.2012, 12:40  [ТС] #6
C++
1
2
3
for(j=0;j<n;j++)
    {for(i=0;i<n-1;i++)
    a[i][j]=a[i+1][j+1]+a[0][j+1]*m[i];}
Вот в чем проблема была, циклы поменять надо было
1
08.10.2012, 12:40
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.10.2012, 12:40
Привет! Вот еще темы с ответами:

Программа для решения систем ОДУ неявный методом Эйлера - C++
Всем доброго времени суток! Очень нужна помощь:

Метод Зейделя для решения слау - C++
Пытаюсь реализовать метод Зейделя, подсмотрев реализацию в Википедии, написала функцию Itera(). Она не рабочая, не считает ничего....

Метод Холецкого для решения Слау - C++
Ты не мог бы выложить программу?

доделать программу для решения СЛАУ - C++
Ребят, помогите пожалуйста, есть программа для решения СЛАУ методом гаусса, но ту слау, которую необходимо решить мне по заданию она не...


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

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

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