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

Шаблон для контейнера stack - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Компилятор ругается на textcolor http://www.cyberforum.ru/cpp-beginners/thread870460.html
компилятор собственно Visual Studio C++ 2010 Express #include "stdafx.h" #include <iostream> #include <stdio.h> #include <conio.h> int main() { textcolor(red); return 0;
C++ Подсчитать в процентном соотношении количество гласных и согласных букв в строке; найти длину самого короткого слова Нужно срочно сделать лабу, помогите пожалуйста) Дана строка длиной n символов, содержащая слова, т.е. группы символов, разделенные пробелами и другими разделителями(знаками препинания) .... http://www.cyberforum.ru/cpp-beginners/thread870444.html
Исправьте код, выдает ошибку (invalid conversion from 'const char*' to 'int') C++
Необходимо сделать структуру TRAIN с полями: - название пункта назначения; - номер поезда; - время отправления. Действия с файлом структур: - сортировка записей в файле по названиям пунктов...
Дан файл , содержащий сведения о книгах. Сведения о каждой из книг – это фамилия автора, название и год издания. а) Найти названия книг данного автор C++
Здравствуйте,я тот несчастный студент,который учился в школе где не было программирования.Поэтому нуждаюсь в вашей помощи.Теорию удалось выучить,а вот с задачами проблема... Дан файл , содержащий...
C++ Написать программу анализирующую лог файл маршрутизатора, отображающую интенсивность сканирования портов по секундам указанной минуты http://www.cyberforum.ru/cpp-beginners/thread870430.html
помогите, пожалуйста с задачами на си: 3. Написать программу анализирующую лог файл маршрутизатора, отображающую интенсивность сканирования портов по секундам указанной минуты. Лог-файл:
C++ Составить программу вычисления суммы элементов вектора помогите, пожалуйста с задачами на си: 2. составить программу вычисления суммы элементов вектора Q=\sum_{i=1}^{N}{a}_{i}^2+{b}_{i}^2. Результат вывести на экран. подробнее

Показать сообщение отдельно
Katii
0 / 0 / 0
Регистрация: 17.05.2016

Шаблон для контейнера stack - C++

19.05.2013, 16:42. Просмотров 504. Ответов 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
class stack
{
    private:
    class Node;
    Node* rootNode;
    Node* lastNode;
  public:
      stack(int){};
      stack(): rootNode(NULL), lastNode(NULL) {}
      ~stack() { delete rootNode; }
      void addValue(int valueToAdd);
  class Iterator : public iterator<forward_iterator_tag, int>
  {
    private: 
    Node* intP;
    public:
        Iterator(){}
    Iterator(Node* p) : intP(p) {}
    ~Iterator() {}
    Iterator& operator=(const Iterator& otherValue);
    bool operator==(const Iterator& otherValue);
    bool operator != (const Iterator& otherValue);
    Iterator& operator++();
    Iterator& operator++(int);
    int& operator*();
   };
 
   Iterator begin();
   Iterator end();
 
  private:
    class Node {
    public:
    Node(const int& val) : nextNode(NULL), nodeValue(val) {}
    int& getVal() {return(nodeValue);}
    Node* nextNode;
    private:
    int nodeValue;
    };
 
};
void stack::addValue(int valueToAdd)
{
    if (rootNode == NULL)
    {
    rootNode = new Node(valueToAdd);
    lastNode = rootNode;
    }else
    {
    Node* p = new Node(valueToAdd);
    lastNode->nextNode = p;
    lastNode =p;
    }
}
 
stack::Iterator& stack::Iterator::operator=(const Iterator& otherValue)
{
  intP = otherValue.intP;
  return (*this);
}
 
bool stack::Iterator::operator==(const Iterator& otherValue)
{
    return (intP == otherValue.intP);
}
 
bool stack::Iterator::operator != (const Iterator& otherValue)
{
    return (intP != otherValue.intP);
}
 
// increment the pointer to the next value
stack::Iterator& stack::Iterator::operator++()
{
    if (intP != NULL)
      intP = intP->nextNode;
    return (*this);
}
 
stack::Iterator& stack::Iterator::operator++(int)
{
    if (intP != NULL)
      intP = intP->nextNode;
    return (*this);
}
 
int& stack::Iterator::operator*()
{
    return(intP->getVal());
}
 
stack::Iterator stack::begin()
{
  return(Iterator(rootNode));
}
 
stack::Iterator stack::end()
{
  return(Iterator(NULL));
}
 
int main(int argc, char **argv) {
    setlocale(LC_ALL, "RUS");
    stack stacky;
    //stack<Prepod_Univera>stacky;
    //Prepod_Univera ch;
    stacky.addValue(ch);
    stacky.addValue(10);
    stacky.addValue(3);
    printf("Value in the stack was\n");
    for (stack::Iterator theIterator= stacky.begin(); theIterator != stacky.end(); theIterator++)//print
    {
        cout<<endl;
    cout<<((int)*theIterator);
    cout<<*theIterator++;
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.