汇编学习笔记,如何求一个数的阶乘

     最近看了不少汇编教程,也小有收获,至少看汇编的算法不向以前那么头疼了,下面我就谈谈我学习中遇到的一个典型问题,如何求一个数的阶乘.

一:

  
include windows.inc
include stdio.inc
.data
 a dd 4
 s db 10 dup(?)
.code
fact proc
mov eax,[esp+8]
dec ebx
cmp ebx,1
jge f1
jl f2
f1: mul ebx
push eax
invoke fact
f2: ret
endp
Start:
mov eax,a
mov ebx,eax
push eax
 invoke fact
 invoke sprintf,offset s,"%d",eax
 invoke MessageBox,0,offset s,"asd",0
exit: invoke ExitProcess,0

end Start

二:

 
include windows.inc
include stdio.inc
.data
 a dd 5
 s db 10 dup(?)
.code
Start:
mov eax,a
mov ecx,eax
dec ecx
w:  mul ecx
loop w
 invoke sprintf,offset s,"%d",eax
 invoke MessageBox,0,offset s,"asd",0
exit: invoke ExitProcess,0

end Start

上面两种方法前一种用的是递归,后一种是迭代,代码不难理解,那个递归的无非也就是压栈以及取栈里的值,大家应该可以看出,递归的明显要比迭代的麻烦,代码量多不说,还涉及到连续压栈,怪不得当初学算法时书上说,递归固然优美,但还是不推荐我们用递归,能用迭代的就用迭代代替,现在想想不无道理啊.

    顺便说下,以上代码在btasm下编译通过,可能我用的不是正统的masm,所以文章不足之处还望指正.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值