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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.90
BeautifulLie
0 / 0 / 0
Регистрация: 23.12.2011
Сообщений: 12
#1

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

23.12.2011, 08:56. Просмотров 1331. Ответов 4
Метки нет (Все метки)

Создать стек целых чисел на основе статического массива. Реализовать методы : Добавить элемент, удалить элемент, вершина стека.

 Комментарий модератора 
  • На каждый вопрос создавайте по одной теме - это помогает избежать путаницы в ответах и облегчает поиск.
  • Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.12.2011, 08:56
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Создать стек целых чисел на основе статического массива. (C++):

Стек на основе статического массива - C++
Здравствуйте! Помогите пожалуйста выполнить задание. Сама уже весь форум облазила и нужного не нашла. Создать стек записи...

Стек записи на основе статического массива типа запись - C++
Добрый вечер! Помогите пожалуйста выполнить задание: Создать стек записи Спортсмен на основе статического массива типа запись. ...

Стек на основе статического массива: вставить число, учитывая сортировку - C++
всем привет. помогите решить проблему с методом pushOrder(). Его суть в том, что бы вставить число учитывая сортировку массива. ...

Создать структуру, реализующую стек целых чисел типа LIFO - C++
Создать структуру, реализующую стек целых чисел типа LIFO. Данные структуры: массив стека, указатель на вершину стека. Создать функции:...

Создать стек из случайных целых чисел и отсортировать элементы по возрастанию (убыванию) - C++
Здраствуйте!Можете помочь с заданием???Дана программа: #include <iostream> #include <malloc.h> using namespace std; /* run this...

Стек на базе статического массива - C++
Здравствуйте помогите, верней напишите за меня пожалуйста стек на базе статического массива. требования для массива: 1)тип элементов -...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
lemegeton
2923 / 1352 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
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
Эксперт С++
5771 / 3420 / 255
Регистрация: 08.02.2010
Сообщений: 7,447
23.12.2011, 12:59 #3
а зачем удаление begin_ в деструкторе?
lemegeton
2923 / 1352 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
23.12.2011, 16:42 #4
Цитата Сообщение от Nameless One Посмотреть сообщение
а зачем удаление begin_ в деструкторе?
Пардон, изначально использовал динамическую память. Деструктор надо удалить.
Beautiful Lie
Сообщений: n/a
23.12.2011, 17:17 #5
нет, пропустил месяц =\ сори за кривую тему, можете удалить, спасибо тем кто откликнулся
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.12.2011, 17:17
Привет! Вот еще темы с ответами:

Очередь на основе статического массива - C++
в очередь с экрана вводятся строки,когда вводится строка end,элементы извлекаются из очереди и записываются в файл. xD.h #include...

Очередь на основе динамического (статического) массива - C++
Задание следующее: Абстрактный класс (интерфейс) - это у меня очередь Дочерние/производные классы (драйверы) - 1)Очередь на основе...

Создать генератор чисел на основе массива из 3 елементов - C++
Нужно сделать генератор чисел на основе массива из 3 елементов. Например 000, 001, ... , 011, 012, ... , 999 Никак не могу цикл...

Создать стек на основе контейнера vector - C++
На основе контейнера vector построить стек целых чисел. Выполнить операции занесения элемента в стек, извлечение значения с вершины стека,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
23.12.2011, 17:17
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru