Как создать стек для рекурсивной функции?02.08.2015, 13:27. Показов 1908. Ответов 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 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
|
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git
main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели
8ATzM_2aurI
|
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2.
Задача: запретить редактирование документа, если он открыт у другого пользователя.
/ / . . .
|
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои.
А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
|