所以我的任务是编写汇编代码,在一组数字上执行前缀和。
给出的示例是2 4 6 -1
,返回值必须为12 10 6
。 -1
可以作为制服者。
jmp main
prefix: addl %edx, %eax
ret
print: irmovl $32, %ecx
wrint %eax
wrch %ecx
ret
read: pushl %ebp # ON_ENTRY saving old frame ptr
rrmovl %esp, %ebp # ON_ENTRY set new frame ptr
mrmovl 8(%ebp), %edx # Retrieving parameter
irmovl $1, %ecx # writing ecx with 1
addl %ecx, %esi
addl %edx, %ecx # adding edx and ecx
je baseCase # checking if they equal 0
recStep: rdint %ebx # reading parameter from user
pushl %ebx
call read
popl %ebx
mrmovl 8(%ebp), %edx
pushl %edx
call prefix
popl %edx
call print
jmp end
baseCase: irmovl $0, %eax
end: rrmovl %ebp, %esp # ON_EXIT reset stack ptr
popl %ebp # ON_EXIT restore old base/frame ptr
ret # ON_EXIT
main: irmovl $0x1000, %esp # init stack ptr
irmovl $-1, %esi
rdint %ebx # reading parameter from user
pushl %ebx # pushing parameter
call read # function call
popl %ebx # removing parameter
call prtnl
halt
prtnl: irmovl $10, %edx # assuming edx is caller save
wrch %edx
ret
所以基本上我的代码打印6 10 12
,我需要找到一种方法来反转这个输出。有什么想法吗?
答案 0 :(得分:0)
所以基本上我的代码打印6 10 12,我需要找到一种方法来反转这个输出。有什么想法吗?
是的,不要使用递归 - 没有理由滥用堆栈。
而是在获得它时将每个输入保存到堆栈中。然后将其视为一个数组 - 遍历每个项目并计算它的前缀和。我要做的是使用一个寄存器来指示第一个项目在堆栈上的起始位置,并使用esp
之间的差异来获得数组长度。当收到输入时,我还会使用另一个寄存器来累加和。
每个元素的前缀和可以通过从当前array[i]
中减去累加器并将结果存回到累加器中来计算下一个元素。