题目:
汇编语言计算N! (0N9)。
代码:
#include <iostream>
using namespace std;
int main()
{
ios::sync_with_stdio(false);
cin.tie(0),cout.tie(0);
int n,sum = 0; //n的范围是0~9
cin >> hex >> n; //输入一个16进制的数字n
__asm //嵌入汇编语言代码段
{
mov eax,0001H //EAX保存和,先清零
mov ebx,0001H //EBX=当前元素
mov ecx,n //ECX=数据个数
fun:
imul eax,ebx //乘积存放在EAX中
inc ebx //EAX自增
cmp ebx,ecx //比较当前元素和数据个数间的大小
jna fun //不能用JB,得用JNA,EBX小于等于ECX时继续循环
mov sum,eax
}
printf("%x! = %d",n,sum);
return 0;
}