汇编语言程序设计 实验4 算术及位串处理程序

本文档介绍了四个汇编语言编程实验,包括:根据输入的十六进制数显示对应的ASCII码;实现32位加减乘除运算并分析标志位;进行字符串的比较和查找操作,强调在Debug环境下执行和验证;以及实现AL字节内容的反向排序。通过这些实验,读者可以深入理解汇编语言的算术和位串处理能力。
摘要由CSDN通过智能技术生成

本文档为个人博客文档系统的备份版本、作者:小游、作者博客:点击访问

这里我为了方便大家就直接贴代码了

1. 在数据段预先存放16个十六进制的ASCII码,首地址为ASC。从键盘输入一位十六进制数到BX,用ASC[BX](寄存器相对寻址)寻址方式找到对应数位的ASCII码,并取出显示

data segment
 asc db '0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F' 
;数据段定义,这里我们把这个16进制的ascii码全部存到db中去
;我们这里 给这个字符串取名为asc,db用于定义字节
data ends
; data ends 表示数据段结束
code segment
; assume 用于表示关联,这里我们code段与cs寄存器关联,data段与ds关联
 assume cs:code,ds:data
;  start是标号,表示程序开始执行
start:
; 先把data的值转移到ax中
mov ax,data 
; 把ax寄存器的值转移到ds中
mov ds,ax
; 首先我们给ax的高位置为1
mov ah,1h
; 这个int表示调用dos系统的功能(在使用int21h功能的时候,必须给ah这个寄存器赋值,我们这里赋值1) 
; 这个表示调用DOS 1h号功能:键盘输入并回显,输入的值进入al
int 21h 
; 将al的值赋给bl
mov bl,al 
; bx的h为置为0
mov bh,0 
; 由于下面要与40h比较而cmp必须是高精度比较
; cmp是比较函数,比较的结果会影响ZF,SF ,
; 如果ZF=1则AX=BX 
; 如果ZF=0则AX!=BX 
; 如果SF=1则AX<BX 
; 如果SF=0则AX>=BX
cmp bx,40h
; 由于A的ascii码是40h,小于则是数字,大于等于则是字母
; jns用于判断符号为不为1,如果不为1那么就跳转到test这段
; alp为alpha即字母SF=0未产生标志位则说明bx比A大是字母跳转到alp
jns alp
js num;否则跳转到num
num:sub bx,30h;bx为数字(因为数字0的ASCII为48,16进制为30,所以我们减去30)
    jmp over ; 跳转到over函数
alp:sub bx,37h;减去37h则为数字
    jmp over
over:mov cl,asc[bx];cl的值是对应数位的ascii码 这里我们给cl寄存器放入asc这个数组对应的字符串
     mov dl,cl
     mov ah,2 ;调用DOS 2h号回显功能,注意回显功能只能显示dl,所以我们需要把内容放到d1中
     int 21h
    ; 4表示 异步通迅输出
    mov ah,4ch
    int 21h;结束
code ends
end start

5.1试编写一个汇编语言程序,要求对键盘输入的小写字母用大写字母显示出来。 5.2 编写程序,从键盘接收一个小写字母,然后找出它的前导字符和后续字符,再按顺序输出 5.3 将AX寄存器中的16位数分成4组,每组4位,然后把这四组数分别放在AL、BL、CL、DL中。 5.4 试编写一程序,要求比较两个字符STRING1和STRING2所含字符是否相同,若相同则显示‘MATCH’,若不相同则显示‘NOT MATCH’。 5.5 试编写一程序,要求能从键盘接收一个个位数N,然后响铃N次。 5.6 编写程序,将一个包含有20个数据的数组M分成两个数组:正数数组P和负数数组N,并分别把这两个数组中的数据的个数显示出来。 5.7 试编制一个汇编语言程序,求出首地址为DATA的100D字数组中的最小偶数,并把它放在AX中。 5.8 把AX中存放16位二进制数K看作是8个二进制的“四分之一字节”。试编写一个程序,要求数一下值为3(即11B)的四分之一字节数,并将该数在终端上显示出来。 5.9 试编写一汇编语言程序,要求从键盘接收一个四位的十六进制数,并在终端上显示与它等值的二进制数。 5.10 设有一英文,其字符变量名为ENG,并以$字符结束。试编写一程序,查对单词SUN在该文中的出现次数,并以格式”SUNXXXX“显示出次数。 5.11 从键盘输入一系列以$为结束的字符,然后对其中的非数字字符进行计数,并显示出计数结果。 5.12 有一个首地址为MEM的100D字数组,试编制程序删除数组中所有为零的项,并将后续项向前压缩,最后将数组的剩余部分补上零。 5.13 在STRING到STRING+99单元中存放着一个字符,试编制一程序测试该字符中是否存在数字,如有,则把CL的第五位置1,否则置0. 5.14 在首地址为TABLE的数组中按递增次序存放着100H个16位补码数,试编写一个程序把出现次数最多的数及其出现的次数分别放在AX和CX中。 5.15 数据中已定义了一个有N个字数据的数组M,试编写一程序求出M中绝对值最大的数,把它放在数据的M+2n单元中,并将该数的偏移地址存放在M+2(n+1)单元中。 5.16 在首地址为DATA的字数组中,存放了100H个16位补码数,试编写一个程序求出它们的平均值放在AX寄存器中;并求出数组中有多少个数小于此平均值,将结果放在BX寄存器中。 5.17 试编写一个程序,把AX中的十六进制数转换为ASCII码,并将对应的ASCII码依次存放到MEM数组中的四个字节中,例如:当(AX)=2A49H时,程序执行完后,MEM中的4个字节的内容为39H,34H,41H和32H。 5.18 把0~100D之间的30个数存入以GRADE为首地址的30个字数组中,GRADE+i表示学号i+1的学生的成绩。另一个数组RANK为30个学生的名次表,其中RANK+i的内容是学号为i+1的学生的名次。编写一程序,根据GRADE中的学生成绩,将学生名次填入RANK数组中。 5.19 已知数组A包含15个互不相等的整数,试编写一程序,把既在A中又在B中出现的整数存在于数组中C中。 5.20 设在A,B和C单元中存放着三个数,若三个数都不是0,则求出三树之和并存放于D单元中;其中有一个数为0,则把其他两个数也清零。试编写此程序。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值