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

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

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

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

28.05.2013, 15:43. Просмотров 236. Ответов 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++
В этом коде нужно дописать, что пременная step&lt;=0 иначе errror. Как это сделать ? Вот код. #include &lt;iostream&gt; using namespace...

Нужно поправить код - 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++
Здравствуйте, уважаемые программисты. Прошу у вас помощи с программой: Методические указания: 1. Ввод и вывод массива, а так же...

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

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

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

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

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

Необходимо понять код - C++
Народ, пожалуйста закомментируйте код #include &lt;iostream&gt; #include &lt;string&gt; #include &lt;memory&gt; class Person { protected: ...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
XRuZzz
Антикодер
649 / 550 / 27
Регистрация: 15.09.2012
Сообщений: 2,497
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-и фиг с ними, мне сейчас бы это сделать, сдавать через полчаса-час надо не больше двух, и не получается. Не знаю, что делать(
Yandex
Объявления
28.05.2013, 16:01     Необходимо поправить код
Ответ Создать тему
Опции темы

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