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

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

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

Необходимо поправить код - C++

28.05.2013, 15:43. Просмотров 243. Ответов 2
Метки нет (Все метки)

в общем программа решает СЛАУ методом Жордана-Гаусса с выбором ведущего элемента, проблема в том, что код вроде бы правильный но выдает ошибку когда я проверяю.
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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
#include "StdAfx.h"
#include <stdio.h>
#include <conio.h>
#include <math.h>
#include <iostream>
using namespace std;
 
int main()
{
  setlocale(LC_ALL, "Russian");
 
  float a[11][11], b[11], x[11], t, p;
  int i, j, k, m, n, l;
   
 cout<<"Метод Жордана-Гаусса с выбором ведущего элемента.\n\n";
  n=3;
 
 
 cout<<"Введите a[1][1]:";
 cin >> a[1][1];
 cout<<"Введите a[1][2]:";
 cin >> a[1][2];
 cout<<"Введите a[1][3]:";
 cin >> a[1][3];
 cout<<"Введите a[2][1]:";
 cin >> a[2][1];
 cout<<"Введите a[2][2]:";
 cin >> a[2][2];
 cout<<"Введите a[2][3]:";
 cin >> a[2][3];
 cout<<"Введите a[3][1]:";
 cin >> a[3][1];
 cout<<"Введите a[3][2]:";
 cin >> a[3][2];
 cout<<"Введите a[3][3]:";
 cin >> a[3][3];
 cout<<"Введите b[1]: ";
 cin >>  b[1];
 cout<<"Введите b[2]: "; 
 cin >>  b[2];
 cout<<"Введите b[3]: ";
 cin >>  b[3];
 
 cout << "\n\n";
  for (i=1; i<=n; i++)
  {
    for (j=1; j<=n; j++)
     cout << a[i][j] << "  ";
    cout << b[i] << "\n";
  }
 
  for(k=1; k<=n-1; k++)
 p=abs(a[k][k]);
    l=k;
   for (i=k+1; i<=n; i++)
 {
  if (abs(a[i][k])>p)
  {
   p=a[i][k];
    l=i;
    
  }
  if (l!=k)
   for (j=k; j<n; j++)
   { 
    t=a[k][j];
    a[k][j]=a[l][j];
    a[l][j]=t;
    
 
  }
 }
    
  
   double eps=.000001;
   double max;
   int max_i;
   double lead, a_div_lead;
 
   for(k=1; k<=n; k++)
   {
 
      max=0;
      max_i=-1;
 
      for(int i=k; i<=n; i++)
      {
     if(fabs(a[i][k])>max)
     {
        max=fabs(a[i][k]);
        max_i=i;
     }
      }
 
 
      if(max_i==-1 || fabs(a[max_i][k])<eps)
      {
        cout << "\n\n" << "Error: det=0" << "\n\n";
        break;
        
    
      }
 
 
 
      lead=a[k][k];
 
      for(j=k; j<=n; j++)
        a[k][j]/=lead;
      b[k]/=lead;
 
      for(i=1; i<=n; i++)
      {
        a_div_lead=a[i][k]/a[k][k];
 
        if(i!=k)
        {
          for(j=k; j<=n; j++)
            a[i][j]-=a[k][j]*a_div_lead;
          b[i]-=b[k]*a_div_lead;
        }
      }
  }
 
  cout << "\n\n";
  for (i=1; i<=n; i++)
  {
    for (j=1; j<=n; j++)
      cout << a[i][j] << "  ";
    cout << b[i] << "\n";
  }
 
 
  getch();
}
Добавлено через 9 минут
Ведущий элемент не меняет как надо к сожалению
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.05.2013, 15:43
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Необходимо поправить код (C++):

Поправить код - C++
В этом коде нужно дописать, что пременная step&lt;=0 иначе errror. Как это сделать ? Вот код. #include &lt;iostream&gt; using namespace...

Поправить код программы - C++
Добрый день, уважаемые программисты. Нашёл нужный код для своего задания, а он не работает. Пытался его переделать,но ничего не вышло. Буду...

Нужно поправить код - C++
Вобщем есть файл txt с парами областей вот пример кусочек Volynska Rivnenska Volynska Lvivska Lvivska Volynska Lvivska...

Поправить немного код - C++
#include &lt;string.h&gt; #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include &lt;iostream&gt; using namespace std; int main() { int...

Поправить код программы - C++
Здравствуйте, уважаемые программисты. Очень нужна ваша помощь - не хочет работать код. Очень благодарен за любую помощь. ...

Поправить код программы - C++
Здравствуйте, уважаемые программисты. Прошу у вас помощи с программой: Методические указания: 1. Ввод и вывод массива, а так же...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
XRuZzz
Антикодер
670 / 571 / 28
Регистрация: 15.09.2012
Сообщений: 2,518
28.05.2013, 16:00 #2
для начала warning-и исправьте которые возникают при компиляции

Добавлено через 6 минут
а потом используйте режим пошаговой отладки

Добавлено через 3 минуты
какой смысл два раза(или n - 1 раз) присваивать разные значения одной переменной
C++
1
2
    for (k = 1; k <= n - 1; k++)
        p = fabs(a[k][k]);
это то же самое, что
C++
1
    p = fabs(a[n - 1][n - 1]);
Reminaru
0 / 0 / 0
Регистрация: 20.04.2013
Сообщений: 14
28.05.2013, 16:01  [ТС] #3
XRuZzz, да warning-и фиг с ними, мне сейчас бы это сделать, сдавать через полчаса-час надо не больше двух, и не получается. Не знаю, что делать(
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
28.05.2013, 16:01
Привет! Вот еще темы с ответами:

Поправить код непростой программы - C++
Здравствуйте. Написал код для вычисления интеграла методом средних прямоугольников, а он не работает. Очень прошу помочь #include...

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

Сортировка в лексографическом порядке(только чуть поправить код) - C++
Есть структура &quot;книга&quot; struct Book { char name; char autor; int year; int number_of_copy; Book* link; }...

Необходимо понять код - C++
Нужна помощь с комментированием кода #include &lt;iostream&gt; using namespace std; class Shape { public: ...


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

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

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