24个汇编实例小程序

2020-04-17 19:03

24个汇编小程序

题目列表:

逆序输出字符串“BASED ADDRESSING”

从键盘上输入两个数,分别放到x,y单元,求出它们的和

是编写一段程序,要求在长度为10h的数组中,找出大于42h的无符号数的个数并存入地址为up开始区域,找出小于42h的无符号数的个数并存入地址为down的开始区域

键盘输入一段字符串,其中小写字母以大写字母输出,其他字符不变输出

从键盘上就收一个小写字母,找出它的前导字符和后续字符,在顺序显示这三个字符

把一个包含20个数据的数组M分成两组:正整数组P和负整数组N,分别把这两个数组中的数据的个数显示出来

求出首地址为data的100个字数组中的最小偶数,并把它放在ax中

输入两船字符串string1和string2,并比较两个字符串是否相等,相等就显示“match”,否则显示“no match”

从键盘接收一个四位的十六进制数,并在终端显示与它等值的二进制数

从键盘输入一系列以$为结束符的字符串,然后对其中的非数字字符计数,并显示计数结果

有一个首地址为mem的100个字的数组,试编程序删除数组中所有为零的项,并将后续项向前压缩,最后将数组的剩余部分补上零

从键盘上输入一串字符(用回车键结束,使用10号功能调用)放在string中,是编制一个程序测试字符串中是否存在数字。如有,则把cl的第五位置1,否则将该位置置0

在首地址为data的字数组中,存放了100h的16位字数据,试编写一个程序,求出平均值放在ax寄存器中,并求出数组中有多少个数小于此平均值,将结果放在bx寄存器中(f分别考虑有符号数、无符号数情况)

一直数组A包含15个互不相等的整数,数组B包含20个互不相等的整数。试编制一个程序,把既在A中又在B中出现的整数存放于数组C中

设在A、B和D单元中分别存放着三个数。若三个数都不是0,则求出三个数的和并存放在S单元,若其中有一个数为0,则把其它两个单元也清零。请编写此程序

从键盘输入一系列字符(以回车键结束),并按字母、数字和其他字符分类计数,最后显示这三类的计数结果

已定义两个整数变量A和B,试编写程序完成以下功能

(1)若两个树种有一个是奇数,则将奇数存入A中,偶数存入B中 (2)若两个数均为奇数,则将两个数加1后存回原变量

(3)若两个数均为偶数,则两个变量均不变

写一段子程序skiplines,完成输出空行的功能。空行的行数由用户在主程序中通过键盘输入,并将行数放在ax寄存器中

设有10个学生成绩分别是76, 69,84,73,88,99,63,100和80。试编写一个子程序统计60-69分,70-79分,80-89分,90-99分和100分的人数,并分别放到S6,S7,S8,S9,S10单元中

编写子程序嵌套结构的程序,把整数分别用二进制和八进制显示出来

在D盘根目录建立一个文件abc.txt,第一次向文件写入“123456”六个字符,第二次增加“abcdefg”几个字符

从键盘上输入文本文件:“d:\\temp.txt”的内容后,然后新建一个文件“d:\\temp2.txt”,把前一个文件的所有内容复制到后一个文件中

从键盘上输入一个十进制数,以十六进制数显示出来。要求子程序用寄存器参数传送方法

试编制一个程序,把bx寄存器中的二进制数用十六进制数的形式在屏幕上显示出来

代码:

1.逆序输出字符串“BASED ADDRESSING”

s1 segment stack ;定义栈段s1 dw 100 dup(?) ;定义栈空间为100 top label word ;top指向栈顶 s1 ends

s2 segment S2 ends

s3 segment

;定义代码段s3

;定义数据段s2

s db 'BASED ADDRESSING','$' ;定义字符串s

assume cs:s3,ds:s2,ss:s1

main proc far

mov ax,s1 ;栈初始化—— mov ss,ax lea sp,top

;——栈初始化

mov ax,s2 ;数据段初始化—— mov ds,ax ;——数据段初始化

mov si,15 l: mov dl,s[si] mov ah,2

;dl获取字符串s的最后一个(从零开始的第十五个字符) ;调用int 21h 2号功能输出dl上的值

int 21h

dec si ;寄存器减一,准备获取下一个字符 cmp si,0

ja l

mov ah,4ch ;终止 int 21h main endp s3 ends

end main

2.从键盘上输入两个数,分别放到x,y单元,求出它们的和

s1 segment stack

dw 100h dup(?) top label word s1 ends

s2 segment

h1 db 'Please input x:','$' ;提示输入 h2 db 'Please input y:','$' ;提示输入 h3 db 'z=x+y:','$' ;提示输出 crlf db 0dh,0ah,24h ;定义回车换行 x dw ? y dw ? s2 ends

s3 segment

assume cs:s3,ds:s2,ss:s3

main proc far

mov ax,s1 ;初始化—— mov ss,ax lea sp,top mov ax,s2

mov ds,ax ;——初始化

lea dx,h1 ;int 21h 9号功能输出“提示输入x”的字符串 mov ah,9 int 21h

xor bx,bx ;bx清零,即把bx置零

InputX: mov ah,1 ;输入一个字符

int 21h

cmp al,0dh ;判断时候为“回车”字符 jz exit1 ;如果是回车字符就跳转到exit1 cmp al,30h ;和30h(即字符0的asii值)比较 jl exit1 ;如果输入字符小于'0',跳转到exit1 cmp al,39h ;和39h(即字符9的ascii值)比较

jg exit1 ;如果输入字符大于'9',跳转到exit1

sub al,30h ;al减去30h,输入字符转化成数字(从这一行开始到后面的add bx,ax为输入字符转化为数字的处理方法) cbw ;al扩充为ax xchg ax,bx 法

jmp InputX

exit1: mov x,bx ;把输入的存于bx的放到x中 lea dx,crlf mov ah,9 int 21h lea dx,h2 mov ah,9 int 21h xor bx,bx

InputY: ;和InputX类似,输入y mov ah,1 int 21h cmp al,0dh jz exit2 cmp al,30h jl exit2

mov cx,10

mul cx xchg ax,bx

add bx,ax ;sub al,30h开始到这一行为输入字符转化为数字的处理方

cmp al,39h jg exit2 sub al,30h cbw

xchg ax,bx mov cx,10 mul cx xchg ax,bx add bx,ax jmp InputY

exit2: mov y,bx ;把输入的存于bx的放到y中 mov bx,x

add bx,y ;此时bx为两数加和

lea dx,crlf mov ah,9 int 21H lea dx,h3 mov ah,9 int 21h

xor si,si ;si清零,用作计数

mov ax,bx ;把和放到ax上

l4: mov cl,10 ;把和连续除以10知道和变为零,余数依次进栈 div cl mov dl,ah mov dh,0 push dx

inc si mov ah,0 ;重要,不能漏写 cmp al,0 jnz l4

l5: pop dx ;余数依次出栈

add dl,30h ;余数转换为显示的余数字符 mov ah,2 ;输入余数字符 int 21h dec si cmp si,0 jnz l5

mov ah,4ch


24个汇编实例小程序.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:面向对象技术的理论研究综述

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: