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

Инстанцирование шаблона для различных типов - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Переводчик с английского на русский http://www.cyberforum.ru/cpp-beginners/thread792628.html
программа переводит введенное (английское)слово на русский,что нужно добавить что бы она переводила 2 и более введенных слов не останавливаясь на переводе первого?"заранее спасибо" #include<iostream> #include<iterator> #include<map> #include<string> #include<fstream> #include<windows.h> #include <locale> using namespace std;
C++ Основы ООП. Создание стека через класс Приветствую всех пользователей форума. Относительно недавно начал осваивать ООП. Было необходимо выполнить следующее задание : нужно описать класс реализующий стек на примере формирования ж/д состава вагоны которого могут быть 2 типов. Конечно же есть некоторый жуткий прототип. Прошу уважаемых пользователей помочь мне в выявлении и пояснении этих ошибок. Среда Билдер. Вот прототип: #include... http://www.cyberforum.ru/cpp-beginners/thread792620.html
C++ литература стандартной библиотеки C++
Вопрос - какую именно скачать книгу для изучения всех библиотек и их метадов. Ну может самых важных, нужных. Искал, интернет выдаёт лабуду. Спасибо!
Обратная матрица третьего порядка C++
Необходимо написать программу в С++, для нахождения обратной матрицы третьего порядка
C++ Упорядочить столбцы матрицы по убыванию элементов в k строке http://www.cyberforum.ru/cpp-beginners/thread792586.html
Дана матрица А(n,m). Упорядочить столбцы матрицы по убыванию элементов в k строке, где k – номер строки, который пользователь вводит с клавиатуры.
C++ Сумма членов последовательности не могу посчитать сумму членов А(n)= 1/2^n + 1/3^n # include <iostream> # include <conio.h> # include <math.h> using namespace std; int main() { int n,c; c=0; double d; подробнее

Показать сообщение отдельно
winst2008
 Аватар для winst2008
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 18
22.02.2013, 19:53     Инстанцирование шаблона для различных типов
Помогите пожалуйста с программой...
Нужно создать шаблон класса, для работы со структурой произвольного типа данных.
В функции main() показать использование созданного класса, включая ситуации, приводящие к генерации исключений; показать инстанцирование шаблона для различных типов (int, float, string).

queue.h
Кликните здесь для просмотра всего текста
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
#pragma once
#include <string.h>
#include <iostream>
#include <conio.h>
 
using namespace std;
 
class queue
    {
    private:
        struct Point
        {
            int key;
            Point *next; 
        };
        Point *pervii_element; 
        Point *tecushii_element;
 
    public:
        queue();
        ~queue(void);
        void operator + (int);
        void operator - (int&);
        void print();
    };

queue.cpp
Кликните здесь для просмотра всего текста
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
#include "queue.h"
queue::queue(void)
{
    pervii_element = 0;
    tecushii_element = 0;
}
queue::~queue(void)
{
    if(pervii_element)//если список не пуст
    {
        tecushii_element=pervii_element;
    }
    while(pervii_element)//пока список не пуст
    {
        pervii_element=pervii_element->next;//взяли следующий элемент
        delete tecushii_element;//освобождение памяти.Удалили текущий
        tecushii_element=pervii_element;
    }
 
}
void queue::operator + (int a)
{
 
    Point* ph = new Point;
    ph->key=a;           //заполнение информатвного поля
    ph->next = 0;
    if (tecushii_element)
    {
        tecushii_element->next = ph;
        tecushii_element = tecushii_element->next;
    }
    else
    {
        pervii_element = ph;
        tecushii_element = ph;
    }
    cout << "Элемент добавлен";
 
}
void queue::operator - (int &a)
{
    if(pervii_element)
    {
   
    Point* ph = pervii_element;
    pervii_element = pervii_element->next;
    delete ph;
    if(pervii_element == NULL)
        tecushii_element = NULL;
    cout<<"Элемент успешно удален....";
    }
    else
    {
         cout<<"Список пуст!";  
    }
}
void queue::print()
{
    if(pervii_element)
    {
    Point* temp=pervii_element;
    cout<<"Список: ";
    while(temp)
    {
        cout << " " << temp->key;
        temp = temp->next;
    }
    cout << endl;
    }
    else
    {
        cout<<"Список пуст!";
    }
}

main.cpp
Кликните здесь для просмотра всего текста
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
#include "queue.h"
 
int main()
{
    setlocale(LC_ALL,"Russian");
    queue w; 
    int b=0,a;
    while(true)
    {
        cout << "1) Добавить элемент в конец очереди"<<endl;
        cout << "2) Вывести на экран очередь"<<endl;
        cout << "3) Извлечь элемент из начала очереди(удалить)"<<endl;
        cout << "4) Выход"<<endl<<endl;
        cout << "Ввод: "; 
        cin >> b;
        switch(b)
        {
        case 1 : 
        
            system("cls");
            cout<<"Введите значение: ";
            cin>>a;
            w+a;
            system("cls");
            continue;
        
        case 2:
 
                system("cls");
                w.print();
                getch();
                system("cls");
                continue;
 
        case 3:
        
                system("cls");
                w-a;
                getch();
                system("cls");
                continue;
        
        case 4:
        
                 break;
        
        default: cout<<"Error!"<<endl<<endl;
                 continue;
        }
        break;
    }
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 23:30. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru