2013-03-30 65 views
2

我无法写一个生成奇数交替的迹象从1开始OAM汇编语言澄清

我写了一个程序,但它不工作,我不知道为什么一个序列的OAM方案。因为这是一种罕见的语言,如果任何人都可以帮助和解释我做错了什么,那将会很棒。

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 
+0

这个问题很不清楚。序列应该有多久?什么是'X'和'Y'应该用于(我猜''X'是一个循环计数器,'Y'是当前的序列元素,但是这在任何地方都没有解释过)?生成一个序列意味着使用循环,那么为什么代码中没有分支指令? “SET”后面紧跟着一个“LDA”是什么意思? 'STA X'紧跟着'LDA X'后面是什么意思? – Michael

回答

0

注其他读者想知道到底这是怎么一回事:
一个基于Web的One Address Machine编译/汇编/仿真器称为OAMulator is here。您需要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存储它。此外,在初始化变量xy后,您还没有从“程序块”分支(BR)开始。我还没有真正看到你的代码是如何将备用标志...

我先写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)和主要(行)编号。 (!编译后)

如果我在input已场内输入50(回答最大值问题)和命中execute,我得到以下结果output

enter max number: 
1 
-3 
5 
-7 
9 
-11 
13 
-15 
17 
-19 
21 
-23 
25 
-27 
29 

希望这有助于!