|
0 / 0 / 0
Регистрация: 17.04.2023
Сообщений: 4
|
||||||
Стек. Есть ли ошибки?17.04.2023, 15:10. Показов 1961. Ответов 37
Метки нет (Все метки)
Здравствуйте, пишу стек на плюсах. Подскажите пожалуйста, есть ли ошибки где-то?
0
|
||||||
| 17.04.2023, 15:10 | |
|
Ответы с готовыми решениями:
37
Переменные в стеке. Где хранятся? Как обрабатываются? Есть ли программный стек или только стек процессора? Используя стек проверить есть ли ошибки в заданном арифметическом выражении Стек и дек: Почему стек есть, с ним я могу работать, а дек я должен сам описывать? |
|
118 / 86 / 35
Регистрация: 07.11.2022
Сообщений: 355
|
|
| 18.04.2023, 09:06 | |
|
Catstail, нет . проверка не делается внутри методов push , pop ....
0
|
|
|
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
|
||
| 18.04.2023, 09:16 | ||
|
Более того, push в реализации stl вполне себе кинет исключение, если не хватит памяти. В реализации ТС буфер статического размера, так что по сути проверка "нет памяти" тоже нужна.
1
|
||
|
118 / 86 / 35
Регистрация: 07.11.2022
Сообщений: 355
|
|
| 18.04.2023, 09:18 | |
|
0
|
|
|
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
|
|
| 18.04.2023, 09:19 | |
|
1
|
|
|
118 / 86 / 35
Регистрация: 07.11.2022
Сообщений: 355
|
|||
| 18.04.2023, 09:23 | |||
|
Добавлено через 3 минуты написать stl контейнер (stack) чтобы пройти собеседование ? сдать лабу?
0
|
|||
|
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
|
|||
| 18.04.2023, 09:26 | |||
|
Пока похоже, что вы просто уводите тему в сторону.
0
|
|||
|
118 / 86 / 35
Регистрация: 07.11.2022
Сообщений: 355
|
||
| 18.04.2023, 09:28 | ||
|
0
|
||
| 18.04.2023, 09:33 | |
|
0
|
|
|
118 / 86 / 35
Регистрация: 07.11.2022
Сообщений: 355
|
|
| 18.04.2023, 09:37 | |
|
0
|
|
|
6291 / 3015 / 1051
Регистрация: 01.06.2021
Сообщений: 11,421
|
|
| 18.04.2023, 10:07 | |
|
Вообще, вся библиотека С++, в том числе STL, далеко не эталон и она рассчитана на общие, усредненные случаи. Это компромисс между скоростью, функциональностью, надёжностью и т.д. Если писатель является экспертом и у него есть свободное время, то он может написать свои функции, контейнеры, классы и пр., которые будут работать в разы лучше для его конкретного случая.
Но вот в рамках задания ТС не вижу смысла стараться написать что-то грандиозное, пытаясь подражать стандартной библиотеки или даже ее превзойти. Это же обычное школьное задание, ТС нужен всего лишь банальный пример реализации стека.
1
|
|
|
118 / 86 / 35
Регистрация: 07.11.2022
Сообщений: 355
|
||||||||
| 18.04.2023, 12:25 | ||||||||
|
В ответе Catstail почувствовал проблемы, но скорее интуитивно. И сюда не спорить пришел. Хочу знать как правильно, как сделать лучше, как разрабатывать качественные программы. Хотел дополнить, как сделать лучше. Взять хоть принципы Solid ,а принципы и созданы для того чтобы делать лучше. 1) Принцип единственной ответственности Это означает, что класс и/или метод должен быть ответственен лишь за что-то одно. Если класс/метод отвечает за решение нескольких задач, его подсистемы, реализующие решение этих задач, будут связанными друг с другом. Изменения в одной подсистеме ведут к изменениям в другой. Метод pop() только удаляет верхний элемент из стека и больше ничего другого он делать не должен. 2) Принцип открытости/закрытости Программные сущности (классы, модули, функции и т. п.) должны быть открыты для расширения, но закрыты для модификации. Нам не нужно изменять существующую кодовую базу для добавления новых функций, мы просто строим поверх нее или, что еще лучше, расширяем ее. Нужно проверить что стек не пуст, мы не изменеяем метод pop(), а добавляем в класс стек реализацию метода empty() и используем её. 3) Принцип разделения интерфейсов Клиенты не должны вынужденно зависеть от методов, которыми не пользуются. pop() -- Нужно вытолкнуть элемент из стека всё. В коде, где уже есть проверка, что стек не пустой, нет смысла проверять это снова:
0
|
||||||||
| 18.04.2023, 12:34 | |
|
0
|
|
|
Супер-модератор
|
||
| 18.04.2023, 12:39 | ||
|
Принцип единственной ответственности (если смотреть на него доктртинёрски) - это не что иное, как "к пуговицам претензии есть?" Взять тот же стек. pop и push - опасные операции (в том смысле, что обе могут вызвать крах). Поэтому обе требуют проверки. Если ее не сделать, то код становится опасным. Стоит ли делать ее отдельно? С т.з. производительности, это очевидно хуже (накладные расходы при лишнем вызове метода). Почему в STL это делается без контроля? Не знаю, исходников не видел. К А. Степанову отношусь с глубочайшим уважением. Но и он - не Бог, а человек.
1
|
||
|
0 / 0 / 0
Регистрация: 18.04.2023
Сообщений: 1
|
|
| 18.04.2023, 12:45 | |
|
благодарю!
0
|
|
|
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
|
|||
| 18.04.2023, 12:49 | |||
|
Не по теме: PS Добавлено через 4 минуты ![]() Впрочем, справедливости ради стоит сказать, что именно поведение stack зависит от поведения контейнера, который он использует для хранения данных; прям так и написано в документации. Просто по умолчанию используется deque, у которого (по документации) вот такое поведение - UB при пустом
0
|
|||
|
1070 / 991 / 153
Регистрация: 10.08.2015
Сообщений: 5,413
|
||
| 18.04.2023, 13:33 | ||
|
я просил интересных, чтоб это было не скучно изучать
0
|
||
|
Любитель чаепитий
|
||||
| 18.04.2023, 13:45 | ||||
|
обход дерева в глубину с помощью стека - это метод выполнения задачи.
1
|
||||
| 18.04.2023, 13:45 | |
|
Найти ошибки в данной программе (известно что есть только 2 ошибки)
Мне нужно всего лишь найти синтаксические ошибки, второй день ломаю голову, в условии есть ошибки
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0»
https:/ / ibb. co/ NnkGpfMd
Представленная интегрированная схема описывает непрерывную нелинейную. . .
|
сукцессия 13. Питон модель трехзонного мицелия, пока что в основном арбускулярного
anaschu 28.06.2026
## Разработка агентной модели микоризной сукцессии: от выявления артефактов к созданию комплексной системы
### Аннотация
Представлено исследование по разработке агентной модели микоризной. . .
|
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики
Контекст
Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
|
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии
Введение
Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
|
|
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np
class PlantAgent:
def __init__(self, name, strategy, initial_biomass):
self. name = name
self. strategy = strategy # "greedy" (широколиственные) или. . .
|
сукцессия 9. Математика подлости: как растения предали грибных друзей
anaschu 27.06.2026
Статья 2. Глобальная фосфорная война: эволюционно-экономические механизмы распределения биомов Земли
Введение: Экологический рынок как игра с нулевой суммой
Традиционная экология долгое время. . .
|
сукцессия 8. Как я спорил с ИИ, которые - агенты растений и ненавистники грибов!
anaschu 27.06.2026
Статья 1. Хроники грибного восстания: как Сократов диалог разрушил академические догмы ИИ
Введение: Синдром «цифрового учебника»
Современные большие языковые модели (LLM) обладают колоссальным. . .
|
Главный вопрос моделирования сукцессии
anaschu 27.06.2026
главный вопрос.
Если эктомикориза лучше добывает недоступный фосфор. И ее масса максимальна из всех.
А широколиственный лес тоже имеет самую крутую биомассу.
То почему не возникло их симбиоза? Это. . .
|