我想知道如何在 EASy68k 汇编程序中找到平方根。
我知道这是一个函数,但我不知道它的代码。
我想找到 72 的平方根。
答案应该是一个整数,因此在这种情况下为 8。
我发现了这个算法:
value-->c1
loop:
value/c1-->c2
(c1+c2)/2-->c1
until c1=c2
c1-->result
我将其转换为 68k 代码:
move.w #72,d2 ; value = 64
move.l d2,d5 ; c1 = 64
move.l d5,d3 ; hold d3 = 64
LOOP
divs d2,d3 ; value/c1
move.l d3,d6 ; move answer above to c2 = d6
add.l d5,d6 ; add c1+c2
divs #2,d6
move.l d6,d5 ; move the answer above it do d4 = c1
cmp.l d6,d5
beq loop
move.l d5,d7 ; d7 will have the result
而且由于某种原因它不起作用。