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

Стек на основе статического массива - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Как лучше организовать данные http://www.cyberforum.ru/cpp-beginners/thread700847.html
Добрый день. Создаю класс CError для хранения в нём ошибок. От класса требуется хранить информацию о всех возникающих в процессе работы программы ошибках. Т.е. в функции возникла некритическая ошибка, вместо вывода её прям на месте, мы сохраняем её например таким образом: err.Set("Имя функции", REP_ERR_NO_DATA_IN_AE_MODEL, 1); В подробности вдаваться не будем. Загвоздка возникла в вопросе о...
C++ вот мое задание. Можете с ним помо*ь? Очень надо В целочисленном массиве, сгенерированном случайным образом, найти наименьший из положительных элементов. http://www.cyberforum.ru/cpp-beginners/thread700840.html
C++ Что означает "Программа "[4872] laba!.exe: Машинный код" завершилась с кодом 3 (0x3)."?
при запуске кода компилятор пишет "Программа " laba!!!!!!.exe: Машинный код" завершилась с кодом 3 (0x3)." и появляется окошечко с ошибкой. что это означает и как с этим бороться?
C++ Определить среднее геометрическое отрицательных элементов
Изначально задание такое было: В массиве В, содержащем 16 элементов(заданных в ручную), определить среднее геометрическое отрицательных элементов, расположенных между минимальным и максимальным элементами данного массива. ____ но, думаю, если среднее геометрическое не получится найти, то можно и ср. арифметическое. ___ У меня получается только найти max и min массива, а потом начинается...
C++ Дана строка S и натуральное число N. Создать новую строку, включив в нее все слова из N букв исходной строки http://www.cyberforum.ru/cpp-beginners/thread700818.html
Дана строка S и натуральное число N. Cформировать новую строку, включив в нее все N-буквенные слова исходной строки. Слова в результирующей строке разделять одним пробелом. Знак препинания приравнивать к букве и считать допустимой частью слова. В результирующей строке порядок слов должен быть таким же как в исходной.
C++ Задать размер массива в стороннем файле В файле записано число, допустим 5, нужно считать его и создать массив такого размера ifstream f("file.txt"); int t; f >> t; const int n = t; int mass; Пишет, что n должно иметь константное значение. Что делать? подробнее

Показать сообщение отдельно
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
5552 / 3031 / 337
Регистрация: 29.11.2010
Сообщений: 8,195
18.11.2012, 20:10     Стек на основе статического массива
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
#include <iostream>
#include <cstddef>
#include <string>
 
class Teacher // описываем класс Teacher
{
    public:
        Teacher() {} // конструктор без параметров
        Teacher(std::string name, std::string surname): // аргументированный конструктор, принимает в качестве параметров две строки типа std::string, имя и фамилию
            _name(name), _surname(surname) {} // использует список инициализации
        void set(std::string name, std::string surname) // метод set, меняет свойства класса
        {
            _name = name;
            _surname = surname;
        }
        friend std::ostream& operator<< (std::ostream &output, const Teacher &t) // дружественная функция вывода в потом ostream. Перегружаем оператор <<
        {
            output<< "Name: "<< t._name<< std::endl // помещаем в поток переменные
                  << "Surname: "<< t._surname<< std::endl;
            return output; // вовзращает ссылку на поток std::ostream
        }
    private: // модификатор доступа
        std::string _name, _surname; // свойства класса
};
 
 
class MyStack
{
    public:
        MyStack(): counter(0) {} // неаргументированный конструктор. Инициализирует свойство counter нулем.
        void push(const Teacher &el) // метод push (вставка элемента). принимает в качестве параметра константную ссылку на объект класса Teacher
        {
            if (counter < N) t[counter++] = el; // если счетчик counter меньше N, добавляем элемент (элемент массива t с индексом counter становится равным объекту из параметра), увеличиваем счетчик на 1
        }
        void pop() // функция удаления из вершины
        {
            if (counter > 0) counter--; // еслисчетчик больше 0, то уменьшаем его на 1
        }
        const std::size_t size() const {return counter; } // возвращаем counter (количество элементов в стеке)
        bool empty() {return counter == 0; } // возвращает истину, если количество эл-тов равно 0, иначе ложь
        const Teacher& top() const // возвращает верхний элемент стека (элемент массива с индексом, равным количеству элементов - 1 (т.к. индексация начинается с 0)
        {
            if (counter > 0) return t[counter - 1]; // если счетчик больше 0, то возвращаем элемент
        }
    private:
        enum {N = 10 }; // перечисление, объявляем размер массива N, равной 10
        Teacher t[N]; // создаем массив объектов класса Teacher размерностью N
        std::size_t counter; // счетчик
};
 
 
 
 
int main()
{
    MyStack s; // создаем объект класса MyStack
    s.push (Teacher ("Ivan", "Petrov")); // добавляем в стек объект класса Teacher, образованный аргументированным конструктором, принимающим в качестве параметров имя и фамилию
    s.push (Teacher ("Vladimir", "Voronov")); // аналагично
    while (!s.empty()) // пока стек не пуст
    {
        std::cout<< s.top()<< std::endl; // выводим вершину стека на экран
        s.pop(); // удаляем верхний элемент стека
    }
    return 0; // завершилось без проблем
}
 
Текущее время: 21:26. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru