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

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

Восстановить пароль Регистрация
 
ftg
0 / 0 / 0
Регистрация: 21.10.2013
Сообщений: 6
25.12.2013, 19:24     шаблон класса #1
Помогите написать шаблон класса 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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.12.2013, 19:24     шаблон класса
Посмотрите здесь:

C++ Шаблон класса
Шаблон класса C++
C++ Шаблон класса.
Шаблон класса C++
Шаблон класса (параметризация класса) C++
C++ шаблон класса
C++ Создать шаблон некоторого класса, возможно, реализованного с применением некоторого серверного класса
Шаблон класса C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 10:48. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru