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

шаблон класса - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Переписать программу с помощью функций http://www.cyberforum.ru/cpp-beginners/thread1056610.html
Ребята, не укладываются в голове функции. Эту программу нужно изменить так, чтобы программный код, исполняющий действия пунктов меню, выполнялся в отдельных функциях (по одной на каждый пункт меню)....
C++ Функции, обрабатывающие объект класса Место ошибки подписано в коде (строка 203) Это программа, работающая с "банкоматом": нужно реализовать 3 варианта класса и соответствующих методов/функций снятия/добавления купюр и редактирования... http://www.cyberforum.ru/cpp-beginners/thread1056592.html
C++ Класс динамическая строка и перегрузка операций
Форумчане, привет :) Нужна помощь!:help: Не могу найти, точнее их ликвидировать ошибки.. :( Общая постановка. Пользовательский класс String должен содержать необходимые элементы-данные, которые...
Конструктор, деструктор C++
Дорогие друзья, программисты. Помогите пожалуйста разобраться с конструктором и деструктором, а так же перегрузкой. Фотография прилагается ниже.Очень прошу, код с комментариями, потому что...
C++ Исследовать явлюется ли число дробью http://www.cyberforum.ru/cpp-beginners/thread1056580.html
Нужно понять число дробь или нет. Не могу придумать, помогите!
C++ исправьте ошибки. выводит только целые числа Вычислить и вывести на экран в виде таблицы значения функции F на интервале от Хнач. до Хкон. с шагом dX. где а, b, с - действительные числа. Функция F должна принимать действительное значение,... подробнее

Показать сообщение отдельно
ftg
0 / 0 / 0
Регистрация: 21.10.2013
Сообщений: 6

шаблон класса - C++

25.12.2013, 19:24. Просмотров 184. Ответов 0
Метки (Все метки)

Помогите написать шаблон класса gauss
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
#pragma hdrstop
 
#include "Unit2.h"
#include <math.h>
//---------------------------------------------------------------------------
 
#pragma package(smart_init)
 
class gauss
{
    double** matr;
    double* vek;
    double* otv;
    double* mas;
    int n;
    void func();
public:
    gauss(double** c,double* d,int N);
    friend double* func1(gauss m);
};
 
gauss::gauss(double** c,double* d,int N)
{
    n = N;
    matr = new double*[n];
    for (int i = 0; i < n; i++)
    {
        matr[i] = new double[n];
        for (int j = 0; j < n; j++)
        {
            matr[i][j] = c[i][j];
        }
    }
    vek = new double[n];
    for (int i = 0; i < n; i++)
    {
        vek[i] = d[i];
    }
    mas = new double[n];
    otv = new double[n];
    func();
}
 
void gauss::func()
{
int l, p, M;
double a, b, c;
 
// присвоение компонентам массива перестановок mas(k) исходных значений
       for (int k=0; k<n; k++)
       {
          mas[k] = k;
       }
//Hахождение индекса p
for (int k=0; k<n; k++)
 {
        a=0;
          for (int i=k; i<n; i++)
          {
             l=mas[i];
           if ( fabs (matr[l][k]) < a )
             continue;
             M = l;
             p = i;
             a = fabs ( matr[l][k]  );
          }
      b = matr[M][k]; //Замена местами значения mas[p]  и mas[k], если mas[p] не равно mas[k]
   if (k!=p)
   {
    mas[p] = mas[k];
    mas[k] = M;
   };
   if (b == 0)
   {
 
    break;
   };
        for (int j = k; j<n; j++)    //Исключение переменной otv[k] (прямой ход метода Гаусса)
        {
          matr[M][j] = matr[M][j] / b;
        }
        vek[M] = vek[M]/b;
 
        for (int i = k+1; i<n; i++)
        {
         l = mas[i];
         c = matr[l][k];
              for (int j = k; j<n; j++)
              {
                matr[l][j] = matr[l][j] - c * matr[M][j];
              }
          vek[l] = vek[l] - c * vek[M]; 
         }
   if ( matr[l][n-1] == 0 ) 
   {
    break;
   };
 }
/*Обратный ход метода Гаусса*/
double sum;
       for ( int k = n-1; k>=0; k--)
       {
          l = mas[k];
          sum = 0;
             for (int j = k+1; j<n; j++)
             {
                sum = sum + matr[l][j] * otv[j];
             }
         otv[k] = vek[l] - sum;
        }
}
 
double* func1(gauss m)
{
    return m.otv;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru