0 / 0 / 0
Регистрация: 22.09.2011
Сообщений: 30
1

Задача со стеком

19.11.2011, 02:03. Показов 2645. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Помогите, пожалуйста, со стеком.
Нужно разработать процедуру, которая будет формировать стек Stack. В этот стек должны быть включены по одному разу элементы, которые входят в Stack1, но не входят в стек Stack2.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
19.11.2011, 02:03
Ответы с готовыми решениями:

задача со стеком
Из двух заданных стеков, хранящих символы, создать новый стек из тех символов первого стека,...

Задача с очередями и стеком
здравствуйте, помогите пожалуйста составить код . Условие большое, поэтому я его написал в...

Задача со Стеком и Очередью
Доброго времени суток, прошу помочь в решении задачи, ума не приложу как решать её. = (( Дана...

Придавило стеком, стеком-технологий )
Ребята у меня беда-беда печаль печаль. Выдали мне задание, и... эм, я пипец не понимаю чего мне...

1
4853 / 2653 / 911
Регистрация: 29.11.2010
Сообщений: 5,715
19.11.2011, 03:29 2
Лучший ответ Сообщение было отмечено MOLK как решение

Решение

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
#include <iostream>
#include <stdexcept>
#include <cstdlib>
#include <ctime>
 
template <class ValueType>
class SimpleStack {
 public:
  explicit SimpleStack(size_t size)
    : size_(size), data_(new ValueType[size]), last_(data_) {}
  ~SimpleStack() {
    delete [] data_;
  }
  void push(const ValueType &value) {
    if (last_ > (data_ + size_))
      throw std::runtime_error("Stack overflow.");
    *last_++ = value;
  }
  ValueType pop() {
    if (last_ <= data_)
      throw std::runtime_error("Stack underflow.");
    return *(--last_);
  }
  const ValueType &head() const {
    if (last_ <= data_)
      throw std::out_of_range("Stack is empty.");
    return *(last_ - 1);
  }
  const size_t size() const {
    return last_ - data_;
  }
  friend std::ostream &operator<<(std::ostream &stream, SimpleStack<ValueType> &stack) {
    if (stack.size() == 0)
      return stream;
    ValueType head = stack.pop();
    stream << stack;
    stream << head << " ";
    stack.push(head);
    return stream;
  }
 private:
  size_t size_;
  ValueType *data_;
  ValueType *last_;
};
 
template <class ValueType>
bool doesStackHaveValue(SimpleStack<ValueType> &stack, const ValueType &value) {
  if (stack.size() == 0)
    return false;
  bool result;
  ValueType head = stack.pop();
  if (head == value)
    result = true;
  else
    result = doesStackHaveValue(stack, value);
  stack.push(head);
  return result;
}
 
template <class ValueType>
void fillStack(SimpleStack<ValueType> &stack,
  SimpleStack<ValueType> &stack1, SimpleStack<ValueType> &stack2) {
  if (stack1.size() == 0)
    return;
  int head = stack1.pop();
  if (!doesStackHaveValue(stack, head) &&
    !doesStackHaveValue(stack2, head))
    stack.push(head);
  fillStack(stack, stack1, stack2);
  stack1.push(head);
}
 
int main(int argc, char *argv[]) {
  srand(time(NULL));
  SimpleStack<int> stack(15), stack1(15), stack2(15);
 
  for (int i = 1; i < 10; ++i) {
    stack1.push(rand() % 10);
    stack2.push(rand() % 10);
  }
 
  std::cout << "Stack 1: " << stack1 << std::endl;
  std::cout << "Stack 2: " << stack2 << std::endl;
  
  fillStack(stack, stack1, stack2);
  
  std::cout << "Stack: " << stack << std::endl;
  
  return 0;
}
1
19.11.2011, 03:29
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
19.11.2011, 03:29
Помогаю со студенческими работами здесь

задание со стеком!
из введенных целых чисел сформировать два списка типа стек с одинаковым количеством элементов....

Работа со стеком
Добрый день! Помогите, пожалуйста, с заданием: &quot;Просмотреть элемент в вершине стека без удаления....

Работа со стеком.
Интересует вопрос: для использовония функций pop() и push() нужно ли подключать заголовочный файл...

Работа со стеком
Создать программу, реализовав работу со структурой данных - стеком. В программе реализовать...

работа со стеком
требуется удалить из стэка допустим 5-ый элемент из 10. Как это сделать? И как задать стэк...

Работа со стеком
Доброго времени суток. Мне нужно создать стек и вывести его на экран. Или что-то с вводом или...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru