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

Обобщенный класс - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ определение кол-ва участков м массиве http://www.cyberforum.ru/cpp-beginners/thread230741.html
Дан массив размера N. Определить количество участков, на которых его элементы монотонно возрастают1|убывают2.
C++ Cторон многоугольника Многоугольник задан координатами своих вершин.Определить принадлежит ли заданная точка стороне этого многоугольника. Помогите пожалуйста!не соображу что за условие для точки( Добавлено через 2... http://www.cyberforum.ru/cpp-beginners/thread230738.html
C++ Изменение цвета области формы в зависимости от скролбара
Задание: Написать программу которая будет изменять цвет области формы в зависимости от значений scrallbar. (3 СКРОЛБАРА)
Программа отображающая сортировку массива C++
Задание: Написать программу с графическим интерфейсом отображающую сортировку массива. Все поточные значения массива должны быть отображены на форме.
C++ Ручная сортировка файлов по разрешениям http://www.cyberforum.ru/cpp-beginners/thread230724.html
Всем добрый день. Есть список файлов в текущей папке проекта, пытаюсь забить в vector<string> modelfiles только те, что с расширением .cpp void L_CDialog::InitFileList() { WIN32_FIND_DATA...
C++ Не могу доделать программу(здчу) VC++ Вообщем вот мой код, задача должна работать как на картинке, но что-то у меня не удается, помогите плиз, поставте на путь истинный =) CMyClass.h #ifndef CMYCLASS_H #define CMYCLASS_H ... подробнее

Показать сообщение отдельно
photonr
Заблокирован

Обобщенный класс - C++

18.01.2011, 18:04. Просмотров 1176. Ответов 0
Метки (Все метки)

Есть работающая прога над векторами с ипользованием класса. Нужно немного код изменить. Сделать класс обобщенным, шаблон в общем. template <class T, ... что то такое в общем.


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
136
137
138
139
140
141
142
143
144
145
146
#include "stdafx.h"
 
#include <iostream> // подключаем стандартные библиотеки + библиотеку мат. функций.
#include <windows.h>
#include <math.h>
 
using namespace std;
 
void textrus(char t[])  // функция позволяет выводить русский текст
{
     char s[255];
     CharToOem(t,s);
     cout << s << endl;
}
 
template <class T, int xxx>
class vector3D  // класс трехмерного вектора
{
      public: 
              vector3D();
              ~vector3D();
              
              void SetVector(char *caption); // функция позволяет ввести координаты вектора
              void display(char *caption); // функция выводящая вектор на экран
              void summ(vector3D *vec1, vector3D *vec2); // получает вектор суммы
              void razn(vector3D *vec1, vector3D *vec2); // получает вектор разности
              void dlina(vector3D *vec1); // вычисляет длину вектора
              void scalar(vector3D *vec1, vector3D *vec2);  // скалярно умножает вектора
    
      private:
              T x,y,z; // сами координаты
};
 
vector3D::vector3D() // конструктор класса
{
   x = 0.0;
   y = 0.0;
   z = 0.0;
}
 
vector3D::~vector3D() // пустой деструктор
{
}
 
void vector3D::SetVector(char* caption)
{
     textrus(caption);
     cout << "X = "; cin >> x; // вводим координаты вектора
     cout << "Y = "; cin >> y;
     cout << "Z = "; cin >> z;
}
 
void vector3D::summ(vector3D *vec1, vector3D *vec2)
{
    x = vec1->x + vec2->x; // складываем координаты векторов
    y = vec1->y + vec2->y;
    z = vec1->z + vec2->z; 
}
 
void vector3D::razn(vector3D *vec1, vector3D *vec2)
{
    x = vec1->x - vec2->x; // вычитаем координаты векторов
    y = vec1->y - vec2->y;
    z = vec1->z - vec2->z; 
}
 
void vector3D::dlina(vector3D *vec1)
{
     textrus("ДЛИНА ВЕКТОРА:");
     // ниже мы вычисляем по фрмуле длину вектора  
     float u = sqrt((vec1->x*vec1->x) + (vec1->y*vec1->y) + (vec1->z*vec1->z) );
     printf("%2.2f",u); cout << endl;
}
 
void vector3D::scalar(vector3D *vec1, vector3D *vec2)
{
     float dot = (vec1->x*vec2->x) + (vec1->y*vec2->y) + (vec1->z*vec2->z);
     // строчка выше умножает скалярно два вектора
     textrus("РЕЗУЛЬТАТ СКАЛЯРНОГО ПРОИЗВЕДЕНИЯ ВЕКТОРОВ:");
     printf("%2.2f",dot); cout << endl;
}
 
 
void vector3D::display(char *caption)
{
     textrus(caption);
     textrus("Вектор с координатами:");
     cout << "X = "; printf("%2.2f",x); cout<<endl;
     cout << "Y = "; printf("%2.2f",y); cout<<endl;
     cout << "Z = "; printf("%2.2f",z); cout<<endl;
}
 
int main(int argc, char *argv[])
{
    // обьявляем экземпляры класса, у нас 2 вектора для работы и один для результатов
class <float, 20>   vector3D *vector1 = new vector3D; 
class <float, 20>    vector3D *vector2 = new vector3D;
class <float, 20>    vector3D *result_vector = new vector3D;
    
    int p; // переменная для выбора в меню далее само меню
    while (true)
    {
        textrus("------------------------МЕНЮ-------------------------");
        textrus("\t1 - Сложение двух векторов");
        textrus("\t2 - Разность двух векторов");
        textrus("\t3 - Высчитать длину вектра");
        textrus("\t4 - Скалярное произведение векторов");
        textrus("\t0 - Выход из программы");
        textrus("-----------------------------------------------------"); 
        
        cin >> p;
        system("cls"); // очистим экран
        
        switch (p) // смотрим что выбрали в меню и вызываем соответствующие функции
        {  
             case 1: 
                     vector1->SetVector("Введите координаты вектора 1:"); 
                     vector2->SetVector("Введите координаты вектора 2:");
                     result_vector->summ(vector1,vector2);
                     result_vector->display("-----------РЕЗУЛЬТАТ----------");
                     break;
             case 2: 
                     vector1->SetVector("Введите координаты вектора 1:"); 
                     vector2->SetVector("Введите координаты вектора 2:");
                     result_vector->razn(vector1,vector2);
                     result_vector->display("-----------РЕЗУЛЬТАТ----------");
                     break; 
             case 3: 
                     vector1->SetVector("Введите координаты вектора:"); 
                     result_vector->dlina(vector1);
                     break;
             case 4: 
                     vector1->SetVector("Введите координаты вектора 1:"); 
                     vector2->SetVector("Введите координаты вектора 2:"); 
                     result_vector->scalar(vector1,vector2);
                     break;
 
             case 0: 
                     exit(0); break; 
        } 
    }
    
    
    system("PAUSE");
    return EXIT_SUCCESS;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru