OAM Assembly Язык разъяснения
У меня возникли проблемы при написании программы OAM, которая генерирует последовательность нечетных чисел с чередующимися знаками, начиная с 1.
Я написал программу, но она не работает, и я не уверен, почему. Потому что это редкий язык, если кто-то может помочь и объяснить, что я делаю неправильно, это было бы здорово.
X,NOOP
Y,NOOP
LDA stdin
loop, SET 1
LDA Y
STA 0
LDA X
DEC
STA X #X = X - 1
LDA X #ACC = X
1 ответ
Примечание для других читателей, интересующихся, что, черт возьми, это все о:
веб-сайт One Address Machine
вызываемый компилятор / ассемблер / эмуляторOAMulator
здесь
Вы проситеOAM program that generates a sequence of odd numbers with alternating signs starting with 1
(без указания максимального значения).
Я интерпретирую, что вы хотите следующий вывод: 1, -3, 5, -7, 9, -11, 13, -15 etc...
,
Я полагаю, вашLDA stdin
предназначен для запроса максимального значения, но вы, кажется, не храните его сSTA
, Также вы не начали с ветвления (BR
) в "программный блок" после инициализации ваших переменных x
а такжеy
, Я также не вижу, как ваш код будет чередоваться...
Я обманул, сначала написавOAMPL
код:
n = 1 #Init number n as 1
PRINT "enter max number:" #Ask for max number
READ i #Read that number from input, storing it as i
LOOP (/ i 2) #Calculate number of iterations, passing that to LOOP
IF t #If t (toggle)
t = 0 #Toggle falsy
PRINT (- 0 n) #Print 0-counter
ELSE
t = 1 #Toggle truthy
PRINT n #Print counter
ENDIF
n = (+ n 2) #Increase counter by 2
END
EXIT #Exit program
это будет соответствовать следующемуOAM Assembly
:
# Emitted by the OAMPL compiler
1. BR 5 # branch to program block
# Variable storage allocation block
2. n, NOOP # variable n
3. i, NOOP # variable i
4. t, NOOP # variable t
# Begin OAM program block
# OAMPL: n = 1
5. SET 1
6. STA n
# OAMPL: PRINT "enter max number:"
7. SET "enter max number:"
8. STA stdout
# OAMPL: READ i
9. LDA stdin
10. STA i
# OAMPL: LOOP (/ i 2)
11. SET 2
12. STA 14
13. BR 15
14. NOOP # intermediate value
15. LDA i
16. DIV 14
17. BR L18
18. NOOP # loop counter
# OAMPL: IF t
19. LDA t
20. BRZ I20
# OAMPL: t = 0
21. SET 0
22. STA t
# OAMPL: PRINT (- 0 n)
23. LDA n
24. STA 26
25. BR 27
26. NOOP # intermediate value
27. SET 0
28. SUB 26
29. STA stdout
# OAMPL: ELSE
30. BR I30
31. I20, NOOP
# OAMPL: t = 1
32. SET 1
33. STA t
# OAMPL: PRINT n
34. LDA n
35. STA stdout
# OAMPL: ENDIF
36. I30, NOOP
# OAMPL: n = (+ n 2)
37. SET 2
38. STA 40
39. BR 41
40. NOOP # intermediate value
41. LDA n
42. ADD 40
43. STA n
# OAMPL: END
44. LDA 18
45. DEC
46. L18, STA 18
47. BRP 19
# OAMPL: EXIT
48. HLT
Примечание: вы также можете оставить комментарии (# comment
) и ведущая (строчная) нумерация.
Если я войду 50
в input
поле (чтобы ответить на вопрос о максимальном значении) и нажмите execute
(после компиляции!), я получаю следующее output
результат:
enter max number:
1
-3
5
-7
9
-11
13
-15
17
-19
21
-23
25
-27
29
Надеюсь это поможет!