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

Создать стек целых чисел на основе статического массива. - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.90
BeautifulLie
0 / 0 / 0
Регистрация: 23.12.2011
Сообщений: 12
23.12.2011, 08:56     Создать стек целых чисел на основе статического массива. #1
Создать стек целых чисел на основе статического массива. Реализовать методы : Добавить элемент, удалить элемент, вершина стека.

 Комментарий модератора 
  • На каждый вопрос создавайте по одной теме - это помогает избежать путаницы в ответах и облегчает поиск.
  • Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
lemegeton
 Аватар для lemegeton
2910 / 1339 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
23.12.2011, 12:42     Создать стек целых чисел на основе статического массива. #2
Судя по количеству тем, кто-то положил болт на целый курс.
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 <iostream>
#include <stdexcept>
 
template <int N>
class Stack {
 public:
  explicit Stack()
    : begin_(), end_(begin_ + N), top_(begin_) {}
  virtual ~Stack() {
    delete [] begin_;
  }
  void clear() {
    top_ = begin_;
  }
  size_t size() const {
    return top_ - begin_;
  }
  void push(int value) {
    if (top_ < end_)
      *top_++ = value;
    else
      throw std::overflow_error("Stack overflow.");
  }
  int pop() {
    if (top_ > begin_)
      return *--top_;
    else
      throw std::underflow_error("Stack underflow.");
  }
  int top() const {
    if (top_ > begin_)
      return *(top_ - 1);
    else
      throw std::underflow_error("Stack underflow.");
  }
 private:
  Stack(const Stack &other);
  Stack &operator=(const Stack &other);
  int begin_[N];
  int *end_;
  int *top_;
};
 
int main(int argc, char *argv[]) {
  Stack<10> stack;
 
  try {
    std::cout << "Top of stack: " << stack.top() << std::endl;
  } catch (std::underflow_error &e) {
    std::cout << "Cannot show top of the stack. It is empty." << std::endl;
  }
 
  try {
    for (size_t i = 0; i < 11; ++i)
      stack.push(i);
  } catch (std::runtime_error &e) {
    std::cout << "Exception caught while pushing data: "
      << e.what() << std::endl;
  }
 
  try {
    std::cout << "Top of stack: " << stack.top() << std::endl;
  } catch (std::underflow_error &e) {
    std::cout << "Cannot show top of the stack. It is empty." << std::endl;
  }
 
  try {
    for (size_t i = 0; i < 11; ++i)
      std::cout << stack.pop() << std::endl;
  } catch (std::runtime_error &e) {
    std::cout << "Exception caught while popping data: "
      << e.what() << std::endl;
  }
}
Nameless One
Эксперт С++
 Аватар для Nameless One
5753 / 3402 / 255
Регистрация: 08.02.2010
Сообщений: 7,393
23.12.2011, 12:59     Создать стек целых чисел на основе статического массива. #3
а зачем удаление begin_ в деструкторе?
lemegeton
 Аватар для lemegeton
2910 / 1339 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
23.12.2011, 16:42     Создать стек целых чисел на основе статического массива. #4
Цитата Сообщение от Nameless One Посмотреть сообщение
а зачем удаление begin_ в деструкторе?
Пардон, изначально использовал динамическую память. Деструктор надо удалить.
Beautiful Lie
Сообщений: n/a
23.12.2011, 17:17     Создать стек целых чисел на основе статического массива. #5
нет, пропустил месяц =\ сори за кривую тему, можете удалить, спасибо тем кто откликнулся
Yandex
Объявления
23.12.2011, 17:17     Создать стек целых чисел на основе статического массива.
Ответ Создать тему
Опции темы

Текущее время: 12:34. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru