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

Решение СЛУ методом Гаусса - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Добавить отсутствующие конструкторы http://www.cyberforum.ru/cpp-beginners/thread214110.html
#include <iostream> using namespace std; class base { int i, j; public: base (int n, int m) { i=n; j=m;} void showij() { cout << i << ' ' << j << '\n'; } };
C++ Циклические программы по накопления суммы или произведения. Массив. Такая задача: Дано одномерный массив С, который состоит из 12 элементов. Вычислить все значения функции, а также сумму значений функций для отрицательных элементов массива. Язык - Си. http://www.cyberforum.ru/cpp-beginners/thread214107.html
C++ программа с массивами
помогите,пожалуйста, студенту написать прогу на си. Такая вот задача Дан одномерный массив А, состоящий из N элементов. Исключить из массива первый отрицательный элемент, следующий за максимальным.
C++ Вычислить бесконечную сумму
Помогите пожалуйста, нужно написать программу на C++ для вычисления бесконечной суммы с заданной точностью, используя рекурентную зависимость:
C++ Программа - календарь на любой месяц любого года http://www.cyberforum.ru/cpp-beginners/thread214076.html
как написать календарь на любой месяц любого года в C++? Добавлено через 3 часа 20 минут Пожалуйста, помогите найти ошибки. #include <iostream> #include <iostream> #include <iomanip> #include <string> using namespace std;
C++ Определить количество пробелов в подстроке, состоящих из первых n сиволов исходной строки Привет друзья:) Столкнулся с такой задачей: Дана строка и натуральное число n. определить количество пробелов в подстроке, состоящих из первых n сиволов исходной строки, и выяснить имеются ли в этой подстроке в точности два соседствующих сивола <<?>>(если вводимое значение n оказывается больше длинны строки, выдать сообщение об ошибке) Добавлено через 25 минут мне хотя бы примерно навести... подробнее

Показать сообщение отдельно
babobka
 Аватар для babobka
1 / 1 / 0
Регистрация: 20.10.2010
Сообщений: 166
Записей в блоге: 1
18.12.2010, 19:52     Решение СЛУ методом Гаусса
Напишите плз прогу, которая будет решать слу методом Гаусса.

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
#include "stdafx.h"
#include "iostream"
#include "conio.h"
using namespace std;
#define nmax 100
 
int _tmain(int argc, _TCHAR* argv[])
{
    int a[nmax][nmax];
    int b[nmax][nmax];
    int c[nmax][nmax];
    int h[nmax][nmax];
    int m[nmax][nmax];
    int n,x,y,yA;
    cout << "Vvedite razmernost'" <<endl;
    cin >> n;
    
    for (int i=1;i<=n;i++)
        for (int j=1;j<=n;j++)
        {
            cout << "Vvedite element A[" <<i<< "][" <<j<< "]" <<endl;
            cin >> a[i][j];
        
        }
    
    for (int i=1;i<=n;i++)
        {for (int j=1;j<=n;j++)
            cout << a[i][j]<<" ";
 
 
        cout << endl;
        }
    getch();
    return 0;
}

Вот примерно на таких условиях.
ps. Кто решит- тому пирожок)

Добавлено через 5 минут
но там ещё будет нужен массив значений b, т.е правая часть

Добавлено через 34 минуты
я немного по-другому запилил. теперь всё выглядит вот так
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
#include "stdafx.h"
#include <stdio.h>
#include <conio.h>
#include <math.h>
#define N 50
 
void glavelem( int k, double mas[] [N + 1], int n, int otv[] )
{
  int i, j, i_max = k, j_max = k;
  double temp;
  //Ищем максимальный по модулю элемент
  for ( i = k; i < n; i++ )
    for ( j = k; j < n; j++ )
      if ( fabs( mas[i_max] [j_max] ) < fabs( mas[i] [j] ) )
      {
        i_max = i;
        j_max = j;
      }
  //Переставляем строки
  for ( j = k; j < n + 1; j++ )
  {
    temp = mas[k] [j];
    mas[k] [j] = mas[i_max] [j];
    mas[i_max] [j] = temp;
  }
  //Переставляем столбцы
  for ( i = 0; i < n; i++ )
  {
    temp = mas[i] [k];
    mas[i] [k] = mas[i] [j_max];
    mas[i] [j_max] = temp;
  }
  //Учитываем изменение порядка корней
  i = otv[k];
  otv[k] = otv[j_max];
  otv[j_max] = i;
  }
void glavelem( int k, double mas[] [N + 1], int n, int otv[] );
 
int main( void )
{
  double mas[N] [N + 1];
  double x[N]; //Корни системы
  int otv[N]; //Отвечает за порядок корней
  int i, j, k, n;
  //Ввод данных
  
  do
  {
    printf( "vvedite 4islo ur " );
    scanf( "%d", & n );
    if ( N < n )
      printf( "Slishkom bol'shoe" );
  }
  while ( N < n );
  printf( "vvedite sistemu:\n" );
  for ( i = 0; i < n; i++ )
    for ( j = 0; j < n + 1; j++ )
      scanf( "%lf", & mas[i] [j] );
  //Вывод введенной системы
  
  printf( "Sistema\n" );
  for ( i = 0; i < n; i++ )
  {
    for ( j = 0; j < n + 1; j++ )
      printf( "%7.2f ", mas[i] [j] );
    printf( "\n" );
  }
  //Сначала все корни по порядку
  for ( i = 0; i < n + 1; i++ )
    otv[i] = i;
  //Прямой ход метода Гаусса
  for ( k = 0; k < n; k++ )
  { //На какой позиции должен стоять главный элемент
    glavelem( k, mas, n, otv ); //Установка главного элемента
    if ( fabs( mas[k] [k] ) < 0.0001 )
    {
      printf( "Net reshenii" );
      return ( 0 );
    }
    for ( j = n; j >= k; j-- )
      mas[k] [j] /= mas[k] [k];
    for ( i = k + 1; i < n; i++ )
      for ( j = n; j >= k; j-- )
        mas[i] [j] -= mas[k] [j] * mas[i] [k];
  }
  //Обратный ход
  for ( i = 0; i < n; i++ )
    x[i] = mas[i] [n];
  for ( i = n - 2; i >= 0; i-- )
    for ( j = i + 1; j < n; j++ )
      x[i] -= x[j] * mas[i] [j];
  //Вывод результата
  printf( "Ответ:\n" );
  for ( i = 0; i < n; i++ )
    for ( j = 0; j < n; j++ )
      if ( i == otv[j] )
      { //Расставляем корни по порядку
        printf( "%f\n", x[j] );
        break;
      }
  return ( 0 );
  getch();
}


у меня проблема в том, что окно с результатом вылетает быстрее , чем я его замечу, плз помогите. Вроде гетч поставил
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 12:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru