我正在尝试在装配中打印1-100的素数,但不仅是我的代码打印出额外的数字,而且还排除了一些素数。
这是我的主要程序:
mov min, 1
loopStart:
inc min ; min++
mov eax, min
cmp eax, max ; compare 2 and 100
je next ; jump unless 2 < 100
call isPrime ; check if prime
cmp ecx, 0
jne loopStart
push eax
call printPrime ; print the prime numbers
pop eax
jmp loopStart
next: ; once max is 100
push 0
call ExitProcess
我的isPrime是:
mov prime, 0 ; set as true
mov ecx, prime
mov k, 2 ; reset k
mov edx, 0 ; clear edx
div num ; n/2
mov edx, 0 ; clear edx again
start:
cmp ecx, 0 ; while prime
jne E ; if prime isnt true
cmp eax, k ; k<=n/2
jl E
mov eax, min
div k
cmp edx, 0 ; check for remainder
jne kAdd
mov prime, 1 ; set as false
jmp E
kAdd:
inc k
jmp start
E:
mov ecx, prime
mov eax, min
ret
isPrime endp
打印出:2 3 5 7 13 15 19 21 25 31 33 37 39 43 49 51 55 57 61 63 67 73 75 79 81 85 91 93 97 99
大多数额外数字是否可被3,5和7整数(都是素数)与某事有什么关系?
答案 0 :(得分:1)
您未在EDX
的循环内正确重置isPrime
。也就是说,在div k
之前,您需要设置mov edx,0
或xor edx,edx
。
另外,我不确定num
在函数开头的div num
中来自何处(?)。评论说您要除以2,那么您的意思是div k
吗?
你的程序中有一些不必要的代码。像这样检查:
cmp ecx, 0 ; while prime
jne E ; if prime isnt true
如果你看一下代码的其余部分,应该清楚ECX
在这一点上永远不会有任何其他值而不是零。
答案 1 :(得分:0)
在k = k + 1
处增加k时,您忘记清除edx