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

необходимо сделать шаблон класса, не знаю как - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ поиск самого длинного симметричного слова http://www.cyberforum.ru/cpp-beginners/thread1051766.html
дано предложение оканчивающееся точкой, найти самое длинное симметричное слово в этом предложение. Помогите написать программу на С++, я уже неделю не могу написать.
C++ задание цвета текста в зависимости от введенного числа Всем привет, помогите написать задачу: Написать программу, которая, в зависимости от введенного числа, выводит цвет, которому оно соответствует. 0 = Черный, 1 = Синий, 2 = Зеленый, 3 = Голубой, 4 =... http://www.cyberforum.ru/cpp-beginners/thread1051759.html
Выполнение перегрузки функции C++
Нужно выполнить перегрузку функции: # include <iostream.h> # include <conio.h> # include <math.h> void func(int&,int&); void main () { clrscr();
Найти наибольшее и наименьшее числа, которые можно представить типами C++
Найти наибольшее и наименьшее числа, которые можно представить типами int, long int, short int, float и double в своей среде программирования Такое задание, кто-нибудь с таким сталкивался? не...
C++ MCB блоки http://www.cyberforum.ru/cpp-beginners/thread1051745.html
нужно написать маленькую программку на С++, в которой надо запустить другую программу и вывести MCB блоки, используя 21 прерывание 52h (просто я не знаю как это делать к сожалению )
C++ Даны два множества точек на плоскости. Из первого множества выбрать три различные точки так, чтобы треугольник с вершинами в этих точках содержал (ст Уважаемые в чем проблема #include "stdafx.h" #include "conio.h" #include "time.h" #include "math.h" #include "stdlib.h" #include "iostream" void rfv(float *A, int M, int N, int D) подробнее

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

необходимо сделать шаблон класса, не знаю как - C++

22.12.2013, 12:48. Просмотров 192. Ответов 0
Метки (Все метки)

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
//---------------------------------------------------------------------------
 
 
#pragma hdrstop
 
#include "Unit2.h"
#include <math.h>
//---------------------------------------------------------------------------
 
#pragma package(smart_init)
template <class T>
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