The function F is defined as F(1) = F(2) = F(3) = 1 and for n 3,
F(n + 1) = F(n) (F(n - 1) + F(n - 2))
i.e., the (n + 1)th value is given by the product of the nth value and
the sum of the (n - 1)th and (n - 2)th values.
Write an assembly program for computing the kth value F(k),
where k is an integer bigger than 3 read from a memory location
M, and storing F(k) at memory location M.
Это мой код для вышеуказанного вопроса.Но я столкнулся с проблемой, связанной с выходом.Для 1,2,3,4,5,6 он показывает правый вывод, но для 7 вывод должен быть 72 для 8 он должен быть 1152, а для 9 он должен быть 96768. Нажмите здесь, чтобы увидеть изображение вывода
DATA SEGMENT
NUM1 DB 1
NUM2 DB 1
NUM3 DB 1
k DB ?
RESULT DB ?
MSG1 DB 10,13,"ENTER VALUE OF k: $"
MSG3 DB 10,13,"RESULT F(k) = $"
ENDS
CODE SEGMENT
ASSUME DS:DATA, CS:CODE
START:
MOV AX,DATA
MOV DS,AX
LEA DX,MSG1
MOV AH,9
INT 21H
MOV AH,1
INT 21H
SUB AL,30H
MOV k,AL ; Input value of k stored in k
CMP AL,4
JL SETONE ; if input is less than 4 than set result to 1
MOV BL,3 ; Counter BL = 4
LOOPSTART:
MOV CL,NUM2 ; 2nd Last Value stored in CX
MOV DL,NUM1 ; 3rd Last Value stored in DX
ADD CL,DL ; CX= CX+DX
MOV AL,NUM3 ; Last Value stored in AX
MUL CL ; AX= AX*CX
;ADD AX,30H
AAM
MOV DH,NUM2
MOV NUM1,DH
MOV DH,NUM3
MOV NUM2,DH
MOV NUM3,AL
INC BL
MOV CL,k
CMP BL,CL
JNE LOOPSTART
JMP SHOWRESULT
SETONE: ; jump here if k is less than 4
MOV AL,1 ; set result = 1
MOV RESULT,AL
SHOWRESULT:
ADD AH,30H
ADD AL,30H
MOV BX,AX
LEA DX,MSG3
MOV AH,9
INT 21H
MOV AH,2
MOV DL,BH
INT 21H
MOV AH,2
MOV DL,BL
INT 21H
MOV AH,4CH
INT 21H
ENDS
END START
Дополнительно: Алгоритм решения этой проблемы также доступен в ответе № 1. Мое задание говорит о сохранении результата в памяти.Но я хочу показать результат для изучения перспективы.