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

Классы и работу с ними - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Разложить N камней на M Куч http://www.cyberforum.ru/cpp-beginners/thread1037205.html
Всем доброго времени суток! Возникла проблема с решением одной задачи - необходимо разложить N камней на M куч таким образом, чтобы минимизировать вес самой тяжелой кучи. Можете подсказать хотя бы в...
C++ Обработка исключений Ребят, всем привет) помогите разобраться с вроде как простой задачкой, но весьма затруднительной для меня) По исключениям инфы мало в Сети, если она есть - то она одинаковая везде и во-многом не... http://www.cyberforum.ru/cpp-beginners/thread1037178.html
C++ Из float в string
Как из переменной типа флоат записать число в string? float x = -123.56; string Str; Нужно чтобы Str стало равно "-123.56"
Программа с двусвязным списком крашится C++
Здравствуйте! написал код для двусвязного списка, проблема следующая: все компилируется, запускается интерфейс, но какую бы функцию я не вызывал - окно вылетает ("прекращена работа...") ...
C++ Преобразование типа http://www.cyberforum.ru/cpp-beginners/thread1037125.html
Есть числа типов int и double. Их надо преобразовать в тип char, чтобы записать их в поток(файл *.bin). И какая функция соединяет строки? Например stroka1+stroka2+...+strokaN в вид одна большая...
C++ Программа вылетает на delete[] Line Подскажите, кто-нибудь. Программа вылетает на delete Line; не пойму почему, вроде, все синтаксически правильно... int Size = 1, Step = 2; char * Line = new char ; int Count = 0, i = 0; ... подробнее

Показать сообщение отдельно
saserlend
11 / 11 / 1
Регистрация: 25.11.2011
Сообщений: 145
11.12.2013, 16:59  [ТС]
Цитата Сообщение от egor2116 Посмотреть сообщение
А что конкретно, напомни.
Вот на днях написал. И здесь я как то сделал, но не понял толком как. Вот тут у меня обращение queue.func(). А queue это указатель. Я не мог понять на что. А теперь как я понял это просто указатель на родовой тип.
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
#include <iostream>
using namespace std;
 
template < class T > class Queue //Шаблонный класс описывающий очередь.
{
protected:
    T *queue; //Указатель на очередь.
    int size; //Начало очереди.
    int tail; //Конец очереди.
public:
    Queue(int n) { //Конструктор.
        size = 0; //Начало = 0.
        tail = n; //Конец = n.
        queue = new T[n]; //Выделение памяти под очередь размером n.
        cout << "Сработал конструктор\n";
        cout << "Создана очередь размером = " << n << "" << endl;
    }
 
    ~Queue() { //Деструктор
        delete []queue; //Удаление очереди.
        cout << "Сработал деструктор\n";
    }
};
 
template < class T > class Node : public Queue<T> //Контейнерный шаблонный класс операций над очередью.
{
public:
    Node( int n ) : Queue<T> ( n ) {} //Создаём очередь.
    void add_item() { //Функция добавление элемента в очередь.  
        T in;
        if( size < tail) { //Если очередь не полна.
            cin >> in; //Вводим элемент очереди.
            int max_size = tail; //Переменная равна концу очереди.
            queue[size] = in; //Добавление элемента в начало.
            size++; 
        }
        else { //Если очередь полна.
            int i = 1;
            cout << "Очередь заполнена\nВведите новый элемент -> ";
            for(; i < tail; i++) { //Если очередь полная, происходит сдвиг.
                queue[i-1] = queue[i];
            }
            cin >> in; //Добавление нового элемента в конец очереди.
            queue[i-1] = in;
        }
        cout << "Очередь -> ";
 
        for(int i = 0; i < size; i++) { //Цикл вывода очереди на экран.
            cout << queue[i] << " ";
        }
 
    cout << "\n";
    }
 
    void find_item() { //Функция поиска элемента
        if (size == 0) { //Если очередь пуста.
            cout << "Очередь пуста\n";
        }
        else { //Если в очереди что то есть.
            T in;
            cin >> in; //Ввод элемента поиска.
            for(int i = 0; i < tail; i++) { //Цикл поочередной проверки элементов очериди на совпадение с введенным.
                if(in == queue[i]) { //Если введенный элемент есть в очереди.
                    cout << "Номер элемента: " << i+1 << " это " << in;
                }
            }
        }
        cout << endl;
    } 
};
 
int check_int() //Функция проверки ввода(исключительная ситлуация)
{
    int i, flag = 0;
    char ch[10];
    cin >> i;
    flag = cin.rdstate(); //Функция-член rdstate() позволяет получить текущее состояние объекта
    if (flag& ios :: failbit) { //Если введена буква.
        cin.clear(); //Сброс текущего состояния и установки одного или нескольких флагов нового
        cin >> ch;
        throw 1; //Ключевое слово, "создающее" ("возбуждающее") исключение.
    }
    return i;
}
 
int main()
{
    setlocale (LC_ALL, "Russian");
        int index_size = 0; //Рабочая переменная
 
        int flag = 0;
        do
        {
            try { //Начало блока исключений.
                flag = 0;
                cout << "Введите размер очереди: ";
                index_size = check_int(); //Проверка вводимого символа.
            }
            catch(int) { //Начало блока, "ловящего" исключение.
                flag = 1;
                cout << "Ошибка ввода!\n";
            }
         }
        while(flag == 1);
 
        Node<int> queue(index_size);
 
        cout << "Введите очередь.\n";
        for(int k=0, s; k < index_size; k++) {
            queue.add_item();//добавление элемента очереди
            if(k+1 == index_size) {
                l:
                cout << "Добавить элементы?\n1. Да.\n2. Нет.\n";
                cin >> s;
                switch(s) {
                    case 1: { queue.add_item(); goto l;}
                    case 2: break;
                    default: { cout << "Введите правильно\n"; goto l;}
                }
            }
        }
    cout << "Поиск элемента.\nКакой элемент найти?\nЭлемент -> ";
    queue.find_item();
    system("pause");
    return 0;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru