С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
-2 / 1 / 1
Регистрация: 06.06.2013
Сообщений: 65

Реализовать структуру данных стек, содержащую следующие методы:

12.06.2013, 20:59. Показов 2923. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Реализовать структуру данных стек, содержащую следующие методы: добавить элемент в стек, удалить элемент из стека, получить значение с вершины стека, размер стека, считать стек из стандартного потока, записать стек до потока стандартного.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.06.2013, 20:59
Ответы с готовыми решениями:

Описать структуру с именем ., содержащую следующие поля
Описать структуру с именем marsh, содержащую следующие поля: -номер маршрута; -нач точка; -конечная точка; 1.Программа вводит с...

Создать структуру Hotel, содержащую следующие данные
Решите следующую задачу, используя структуры. При решении задач использовать функции: Создать структуру Hotel, содержащую...

Описать структуру с именем AEROFLOT, содержащую следующие поля
Помогите написать программу. Описать запись необходимой структуры. Описать массив этих записей. Реализовать возможность добавления,...

9
...
 Аватар для anmartex
1910 / 1329 / 966
Регистрация: 12.02.2013
Сообщений: 2,172
13.06.2013, 18:01
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
#include <iostream>
#include <stdexcept>
 
template<class T>
class TStack
{
   protected:
      struct TNode
      {
         T data;
         TNode* next;
      }* stack;
 
      TStack(const TStack&);
 
   public:
      TStack(): stack(NULL) { ; }
      ~TStack()
      {
         while (stack)
         {
            Pop();
         }
      }
 
      TStack& Push(T data)
      {
         TNode* node = new TNode;
         node->data = data;
         node->next = stack;
         stack = node;
 
         return *this;
      }
 
      TStack& Pop() throw(std::range_error)
      {
         if (stack == NULL)
         {
            throw std::range_error("stack is empty");
         }
 
         TNode* node = stack;
         stack = stack->next;
         delete node;
 
         return *this;
      }
 
      T& Top() throw(std::range_error)
      {
         if (stack == NULL)
         {
            throw std::range_error("stack is empty");
         }
         return stack->data;
      }
 
      size_t Size() const
      {
         size_t size = 0;
 
         for (const TNode* node = stack; node; node = node->next)
         {
            size++;
         }
 
         return size;
      }
 
      friend std::ostream& operator << (std::ostream& os, const TStack<T>& stack)
      {
         const TNode* node = stack.stack;
 
         for (; node; node = node->next)
         {
            os << node->data << ", ";
         }
         os << "\b\b \b";
         return os;
      }
 
      friend std::istream& operator >> (std::istream& is, TStack<T>& stack)
      {
         T data;
 
         is >> data;
 
         stack.Push(data);
 
         return is;
      }
};
 
int main()
{
   TStack<int> stack;
 
   for (size_t i = 0; i < 5; ++i)
   {
      std::cout << "input " << i + 1 << " of 5: ";
      std::cin >> stack;
   }
 
   std::cout << stack << " : " << stack.Size() << std::endl;
 
   return 0;
}
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
15.06.2013, 11:55
сделать пустым
пуст/не пуст
добавить элемент
взять элемент
прочитать/записать вершину
удалить вершину
0
-2 / 1 / 1
Регистрация: 06.06.2013
Сообщений: 65
15.06.2013, 23:49  [ТС]
accept,Пожалуйста Прошу сделать эти все просьбы!)
0
-2 / 1 / 1
Регистрация: 06.06.2013
Сообщений: 65
17.06.2013, 21:48  [ТС]
anmartex, Прошу тебя реализировать пожалуйста остальное добавить элемент в стек, удалить элемент из стека, получить значение с вершины стека, размер стека, считать стек из стандартного потока, записать стек до потока стандартного.

Добавлено через 1 минуту
anmartex, чтоб в консоле были задани все эти возможности тоисть чтоб например под 1) это добавить елемент в стэк 2) удалить елемент! ну типа того!
0
...
 Аватар для anmartex
1910 / 1329 / 966
Регистрация: 12.02.2013
Сообщений: 2,172
18.06.2013, 04:13
Цитата Сообщение от unikalen Посмотреть сообщение
anmartex, Прошу тебя реализировать пожалуйста остальное добавить элемент в стек, удалить элемент из стека, получить значение с вершины стека, размер стека, считать стек из стандартного потока, записать стек до потока стандартного.
Внимательно посмотрите на класс, это всё уже реализовано:
  1. Push - добавить элемент в стек;
  2. Pop - удалить элемент из стека;
  3. Top - получить значение с вершины стека;
  4. Size - размер стека;
  5. operator << - считать стек из стандартного потока;
  6. operator >> - записать стек до потока стандартного.
0
-2 / 1 / 1
Регистрация: 06.06.2013
Сообщений: 65
18.06.2013, 10:51  [ТС]
anmartex, сделай пожалуйста в консоле чтоб можна било задавать
1) это добавить елемент в стэк 2) удалить елемент 3)получить значение с вершины стека; 4)размер стека;
5)считать стек из стандартного потока; 6)записать стек до потока стандартного.
0
2688 / 2260 / 244
Регистрация: 03.07.2012
Сообщений: 8,231
Записей в блоге: 1
18.06.2013, 11:20
ТС хоть что-нибудь сам запрограммировать может? Или все задания будет делать через форум?
0
-2 / 1 / 1
Регистрация: 06.06.2013
Сообщений: 65
18.06.2013, 11:27  [ТС]
zer0mail, могу! но мне щас по этому именно ваша помощь нада!
0
...
 Аватар для anmartex
1910 / 1329 / 966
Регистрация: 12.02.2013
Сообщений: 2,172
18.06.2013, 15:35
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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
#include <iostream>
#include <string>
#include <stdexcept>
 
template<class T>
class TStack
{
   protected:
      struct TNode
      {
         T data;
         TNode* next;
      }* stack;
 
      TStack(const TStack&);
 
   public:
      TStack(): stack(NULL) { ; }
      ~TStack()
      {
         Clear();
      }
 
      TStack& Push(T data)
      {
         TNode* node = new TNode;
         node->data = data;
         node->next = stack;
         stack = node;
 
         return *this;
      }
 
      TStack& Pop() throw(std::range_error)
      {
         if (stack == NULL)
         {
            throw std::range_error("stack is empty");
         }
 
         TNode* node = stack;
         stack = stack->next;
         delete node;
 
         return *this;
      }
 
      T& Top() throw(std::range_error)
      {
         if (stack == NULL)
         {
            throw std::range_error("stack is empty");
         }
         return stack->data;
      }
 
      void Clear()
      {
         while (!IsEmpty())
         {
            Pop();
         }
      }
 
      size_t Size() const
      {
         size_t size = 0;
 
         for (const TNode* node = stack; node; node = node->next)
         {
            size++;
         }
 
         return size;
      }
 
      bool IsEmpty() const
      {
         return (stack == NULL);
      }
 
      friend std::ostream& operator << (std::ostream& os, const TStack<T>& stack)
      {
         const TNode* node = stack.stack;
 
         for (; node; node = node->next)
         {
            os << node->data << ", ";
         }
         os << "\b\b \b";
         return os;
      }
 
      friend std::istream& operator >> (std::istream& is, TStack<T>& stack)
      {
         T data;
 
         is >> data;
 
         stack.Push(data);
 
         return is;
      }
};
 
int main()
{
   TStack<int> stack;
 
   std::cout << "stack operations:" << std::endl
             << "1. push" << std::endl
             << "2. pop" << std::endl
             << "3. top" << std::endl
             << "4. size" << std::endl
             << "5. view" << std::endl;
 
   bool quit = false;
   std::string command;
 
   while (!quit)
   {
      std::cout << ": ";
      std::cin >> command;
 
      switch (command[0])
      {
         case '1':
            std::cout << "element: ";
            std::cin >> stack;
            break;
 
         case '2':
            try
            {
               stack.Pop();
               std::cout << "element removed" << std::endl;
            }
            catch (const std::range_error& error)
            {
               std::cerr << error.what() << std::endl;
            }
            break;
 
         case '3':
            try
            {
               std::cout << "top: " << stack.Top() << std::endl;
            }
            catch (const std::range_error& error)
            {
               std::cerr << error.what() << std::endl;
            }
            break;
 
         case '4':
            std::cout << "size: " << stack.Size() << std::endl;
            break;
 
         case '5':
            std::cout << "stack: " << stack << std::endl;
            break;
 
         default:
            quit = true;
      }
   }
 
   return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.06.2013, 15:35
Помогаю со студенческими работами здесь

Описать структуру с именем NOTE, содержащую следующие поля
Описать структуру с именем NOTE, содержащую следующие поля: • фамилия, имя; • номер телефона; • день рождения (массив из трех чисел)....

Опистать структуру с именем PRICE, содержащую следующие параметры
1. Опистаь структуру с именем PRICE, содержащую следующие параметры: -название товара; -название магазина в которм продаеться товар; ...

Создать структуру с именем STUDENT, содержащую следующие поля:
Описать Структуру с именем STUDENT с полями 1. NAME-фамилия и инициалы; 2.GROUP-номер группы; 3.SES-успеваемость(массив из 5...

Описать структуру с именем AEROFLOT, содержащую следующие поля:
1. Описать структуру с именем AEROFLOT, содержащую следующие поля: -название пункта назначения рельса -номер рейса -тип самолета 2....

Описать структуру с именем AEROFLOT, содержащую следующие поля:
NUMR – номер рейса (целое число); COST – стоимость билета (число с плавающей точкой); NAZN – название пункта назначения рейса; TIP –...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru