Форум программистов, компьютерный форум, киберфорум
Наши страницы
Assembler, MASM, TASM
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.70/10: Рейтинг темы: голосов - 10, средняя оценка - 4.70
Doberman55590
0 / 0 / 0
Регистрация: 02.02.2010
Сообщений: 10
1

Как реализовать рекурсию через "call" и "ret"?

23.02.2010, 13:07. Просмотров 1914. Ответов 3
Метки нет (Все метки)

kak realizovat rekursiu 4erez "call" i "ret"?
nujno predstavit naturalnoe 4islo v dvoi4nom vide ispolzuya rekursiu i stacki
please pomogite
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.02.2010, 13:07
Ответы с готовыми решениями:

Есть строка. Нужно сделать так, чтобы "re" и "not" заменялись на "***".
Есть строка. Нужно сделать так, чтобы "re" и "not" заменялись на "***". Data...

Изъять слова, которые имеют префикс "re", "not", "be"
Заданы символьная строка. Слова и идентификаторы разделяются хотя бы одним...

Необходимо строку тип ""str1" "str2"",0 преобразовать в строку типа
Необходимо строку тип ""str1" "str2"",0 преобразовать в строку типа "str2",0...

Заменить во вводимом тексте каждое слово "ЭВМ" словом "машина"
Здравствуйте. Поможете разобраться с ниже приведенной задачей: Заменить во...

Дана строка "ababab", из этого слова надо получить "aaa"
Собственно сабж. Дана строка "ababab", надо удалить буквы "b" и получить слово...

3
Kastaneda
Jesus loves me
Эксперт С++
5020 / 3033 / 348
Регистрация: 12.12.2009
Сообщений: 7,644
Записей в блоге: 2
Завершенные тесты: 1
23.02.2010, 20:39 2
Некогда писать всю программу, но общий смысл такой: процедура представляет число в двоичном виде, вызываеться эта процедура командой CALL, при этом (по умолчанию) в стек кладеться адрес следующей строки, на эту строку перейдет управление по команде RET. Задача - поместить а стек адрес команды CALL. (по команде RET процедура вызовет саму себя) Вроде это и есть рекурсия.
1
Doberman55590
0 / 0 / 0
Регистрация: 02.02.2010
Сообщений: 10
24.02.2010, 14:48  [ТС] 3
а как реализоват саму процедуру представления 4исла в двои4ном виде?
0
Kastaneda
Jesus loves me
Эксперт С++
5020 / 3033 / 348
Регистрация: 12.12.2009
Сообщений: 7,644
Записей в блоге: 2
Завершенные тесты: 1
24.02.2010, 15:17 4
Взято отсюда http://www.cyberforum.ru/assembler/thread54461.html
Assembler
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
       
;; если число знаковое, то необходимо расскоментировать следующие строки
;; Проверяем число на знак.
;       test    ax, ax
;       jns     oi1
;
;; Если оно отрицательное, выведем минус и оставим его модуль.
;       mov  cx, ax
;       mov     ah, 02h
;       mov     dl, '-'
;       int     21h
;       mov  ax, cx
;       neg     ax
;; Количество цифр будем держать в CX.
;oi1:  
        xor     cx, cx
        mov     bx, 10 ; основание сс. 10 для десятеричной и т.п.
oi2:
        xor             dx,dx
        div     bx
; Делим число на основание сс. В остатке получается последняя цифра.
; Сразу выводить её нельзя, поэтому сохраним её в стэке.
        push    dx
        inc     cx
; А с частным повторяем то же самое, отделяя от него очередную
; цифру справа, пока не останется ноль, что значит, что дальше
; слева только нули.
        test    ax, ax
        jnz     oi2
; Теперь приступим к выводу.
        mov     ah, 02h
oi3:
        pop     dx
; Извлекаем очередную цифру, переводим её в символ и выводим.
;; раскоментировать если основание сс > 10, т.е. для вывода требуются буквы
;       cmp             dl,9
;       jbe             oi4
;       add             dl,7
;oi4:
        add     dl, '0'
        int     21h
; Повторим ровно столько раз, сколько цифр насчитали.
        loop    oi3
Соответственно в 17ой строке нужно 10 заменить на 2
Assembler
1
mov     bx, 2
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.02.2010, 15:17

Рассматривая массив из 8 пятиразрядных слов, найти "исключающее или" всех 8 слов для выражения "10101"
У меня дан массив из 5 байт. Рассматривая его как массив из 8 пятиразрядных...

Занести в стек "x" и "y". Внести "y" в bx (внести "x" в bx)
Препод задолбал своими вопросами, приходится снова просить помощи у вас. Вот...

Обработка прерывания "ошибочная команда" или "неверная команда"
Привет форумчани! Очень нужна ваша помощь... Нужно написать программу,...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru