Как создать стек для рекурсивной функции?02.08.2015, 13:27. Показов 1925. Ответов 22
Метки нет (Все метки)
Здесь речь идёт вот о чем. Требуется сделать стек,
размер которого будет на порядок больше того, что может дать VB6. И основная проблема даже не в том как управлять этим стеком, а в том, что в него заносить, какие данные? Буду вам очень благодарен если вы приведёте маленький пример. Например надо вычислить 7!. И прокомментировать код. Все остальное я сделаю сам. Мне важно понять принцип. Принцип вызова рекурсивной функции и сохранение в стеке необходимых данных. Добавлено через 4 минуты В качестве стека я собираюсь использовать файл прямого (произвольного) доступа нужного мне размера.
0
|
|
| 02.08.2015, 13:27 | |
|
Ответы с готовыми решениями:
22
Создать стек для символов. Максимальный размер стека вводится с экрана. Создать функции для ввода и вывода элементов стека. Ввести эталонный символ. Создать отдельный стек для функции |
|
|
||||
| 02.08.2015, 14:44 | ||||
Правда, VB6 с асмом не очень дружит и придется использовать опкоды.
1
|
||||
|
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
|
|||||||
| 02.08.2015, 16:03 | |||||||
1
|
|||||||
|
Модератор
|
||
| 02.08.2015, 17:15 | ||
|
Размер стека настраивается в заголовке IMAGE_OPTIONAL_HEADER исполняемого файла. Кстати размер стека можно задать перед компиляцией - ключ /STACK компоновщика.
1
|
||
| 02.08.2015, 17:45 [ТС] | |
|
The Trick, Вы бог программирования.
Не могли бы Вы спуститься на нашу грешную Землю и подсказать мне (доставить радость в Создании самого большого стека в мире), как сделать файловый стек. Только принцип. Ведь Адрес процедуры вещь постоянная. Её надо лишь раз запомнить. А локальные переменные? Ну допустим есть пара локальных переменных. У них тоже адреса постоянные? Или нет? Или да? Что идёт в стек? Их значения? Как? Последовательно при каждом обращении? Чувствую. Я где-то рядом с решением. Вы можете подсказать? Если не вы... Другим не решить. Они так глубоко не копают!
0
|
|
|
Модератор
|
||||
| 02.08.2015, 17:58 | ||||
Сообщение было отмечено echs как решение
Решение
Можно создать просто эмуляцию рекурсии в том числе через файл. На самом деле это будет уже нерекурсивная процедура.
1
|
||||
|
|
||||
| 02.08.2015, 18:02 | ||||
|
1
|
||||
| 02.08.2015, 18:21 [ТС] | |
|
The Trick, большое спасибо.
Красиво! Вы вошли в мою звездную жизнь. Красиво уйдете, растаяв в лазури. Но стек я конечно создам... Как эскимо в шоколадной глазури! Большое Спасибо! Добавлено через 7 минут locm, Вы правы. Я хочу вместо оперативной памяти использовать файл. Ведь его размер может быть колоссальным. А доступ, при прямом доступе, достаточно быстрым. Впрочем скорость большого значения не имеет.
0
|
|
|
|
|||
| 02.08.2015, 18:37 | |||
|
Но как писал выше, железо компа не поддерживает создание стека в файле.
0
|
|||
| 02.08.2015, 18:57 [ТС] | |
|
locm,
Позвольте мне Вам возразить. Во-первых вы правы в том, что процессор не поддерживает файловый стек. Здесь я с вами согласен на все 100%. Но кто мешает нам создать файл прямого доступа, в котором будут определены операции записи в файл и считывания с него так, как это делается в стеке. Специальная переменная будет следить за наполняемостью файла-стека. И когда она станет равной нулю, то это будет означать, что стек чист и вычисление рекурсивной функции окончено. Вероятно это называется эмуляцией стека. Но дело не в терминах. Как бы это не называлось, я достаточно чётко ещё в самом начале темы об этом сказал. P.S. Возможно файл-стек и не будет чист, но нам это безразлично, ибо новая запись пойдёт поверх старой. Что левее указателя, то не существует.
0
|
|
| 03.08.2015, 06:36 [ТС] | |
|
locm, спасибо!
Но я, кажется, нашёл способ сделать глубину рекурсии почти безграничной. В прошлом году я начал создавать программу Десятичный Ассемблер (DAS). Она сильно изменилась по сравнению с той, что я оставил на форуме. Именно там и будет неограниченный стек. Спасибо.
0
|
|
|
|
|
| 03.08.2015, 15:31 | |
|
А у меня, если можно, смежный вопрос: как узнать какой объем стека заняла моя рекурсия в пике и сколько свободного осталось? Хочу узнать вероятность переполнения и может, при необходимости, пропатчить EXE.
0
|
|
|
|
|||||||
| 03.08.2015, 16:09 | |||||||
|
Как это будет выглядеть на VB точно не скажу, но дам пример на другом ЯП. Возможно будет понятно о чем я пишу.
1
|
|||||||
| 03.08.2015, 16:32 | |
|
Не по теме: К сожалению, с ассемблером у меня плохо. Но спасибо, теперь хоть знаю направление.
0
|
|
|
|
||||||
| 03.08.2015, 19:56 | ||||||
|
Так верно?
0
|
||||||
|
Модератор
|
|||||||||
| 03.08.2015, 22:02 | |||||||||
|
Можешь проверить макс так:
Добавлено через 3 минуты
1
|
|||||||||
|
|
|||||||
| 03.08.2015, 22:30 | |||||||
0
|
|||||||
| 03.08.2015, 22:30 | |
|
Помогаю со студенческими работами здесь
20
Применить стек для преобразования рекурсивной подпрограммы обхода дерева поиска в прямом порядке Разработать программу согласно алгоритму с использованием рекурсивной функции и без использования рекурсивной Как создать стек для ввода данных Как можно создать стек, с которым могли бы работать разные функции, записывать в него, удалять?
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2.
Задача: показать затраченные материалы за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом.
В качестве. . .
|
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2.
Задача: отобразить спецтехнику, которая на данный момент находится в ремонте.
Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
|
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
|
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
|
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|