我有這個代碼(having a string of length n, build another of length n-2 as it follows: sir2[i]=(sir[i]+sir[i+1]+sir[1+2])/3
),我不知道它爲什麼凍結。沒有錯誤,我已經調試了一段時間,但我無法弄清楚問題是否與算法有關。x86程序凍結[tasm]
prints macro number
local decompose, pops
mov bx,10
mov al, number
mov cx,0
decompose: ;pushing digits to the stack
inc cx
mov ah,0
div bl
mov dl,ah ; remainder - last digit
add dx,48 ; to transform it in its char version
push dx
cmp al,0
jnz decompose
pops: ; pop digits off the stack
pop dx
mov ah,2h
int 21h
loop pops
; pretty spacing
mov dl,' '
mov ah,2h
int 21h
endm
data segment para public 'data'
sir db 5, 10, 12, 4, 3
n equ $-sir
sir2 db n-2 dup(0)
data ends
code segment para public 'code'
start proc far
assume cs:code,ds:data
push ds
xor ax,ax
push ax
mov ax,data
mov ds,ax
mov si,0
mov dx,3
mov cx,n
sub cx,2
l1:
mov ah,0
mov al,sir[si]
add al,sir[si+1]
add al,sir[si+2] ;sum of 3 numbers
div dx ;sir2[i]=(sir[i]+sir[i+1]+sir[1+2])/3
mov sir2[si],al
inc si
cmp si,cx
jbe l1
mov si,0
l2:
prints sir2[si]
inc si
loop l2
ret
start endp
code ends
end start
任何人都可以幫忙嗎?
你做了什麼努力來發現它爲什麼會凍結,你卡在哪裏?換句話說,**你是否調試過你的代碼**?這個網站不是一個免費的調試服務,因此,就你的問題而言,最有可能的是,它會脫離主題。 –
是的,我做了+我以爲我被困在一個循環,所以我改變它爲一個jmp。 –
您在* decompose *例程中清除了CX!將'mov cx,0'改成'mov ah,0' –