汇编语言: 试编写一段程序,要求在长度为 100H 字节的数组中,找出大于 61H 的无符号数的个 数并存入字节单元 UP 中,找出小于 2FH 的无符号数的个数并存入字节单元 DOWN 中。

试编写一段程序,要求在长度为 100H 字节的数组中,找出大于 61H 的无符号数的个 数并存入字节单元 UP 中,找出小于 2FH 的无符号数的个数并存入字节单元 DOWN 中。

data segment
ARRAY db 61h,62h,63h,64h,65h,66h,22h,24h,28h,24h,55h,54h,'$'
N EQU ($-ARRAY)
up db 0
down db 0
data ends

stack segment stack
dw 20h dup(?)
top label word
stack ends

code segment
    assume ds:data,cs:code,ss:stack
    p proc far 

    mov ax,data
    mov ds,ax

    mov ax,stack
    mov ss,ax
    lea sp,top

    mov al,0 ;up
    mov dl,0 ;down

    lea si,ARRAY
    mov cx,N 
    ; 61h 'a'  2fh '0'  

l1: 
    cmp BYTE PTR[si],61h 
    ja isup
l4: cmp BYTE PTR[si],2fh
    jb isdown
l2: inc si
    loop l1
    jmp result
isup:
    inc al
    jmp l4
isdown:
    inc dl
    jmp l2

result:
    mov up,al
    mov down,dl

    mov bh,al
    mov bl,dl

    mov cx,16
l3: rol bx,1
    mov dl,bl
    and dl,1
    add dl,30h
    mov ah,2
    int 21h 
    loop l3

exit:
    mov ah,4ch
    int 21h

    p endp
code ends 
    end p
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值