汇编输入两个数比较大小.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
汇编输入两个数比较大小

任意输入两个数(不超过16位),把大的输出,如果两个数相等则输出任意一个data segment A dw 0 B dw 0 string1 db please input your first number:$ string2 db please input your second number:$ string3 db the big is:$ data1 db 5 dup(0),$;十六进制--十进制转换时,保存余数的缓冲区 inputdata db 5,?,5 dup(0);输入数据缓冲区 data ends code segment assume cs:code,ds:data start: mov ax,data mov ds,ax lea dx,string1;提示输入A并回车 换行 call display2 call DtoB mov A,ax lea dx,string2;提示输入B并回车 换行 call display2 call DtoB mov B,ax lea dx,string3 call display2 cmp ax,A JG L1 JL L2 L3: JMP L4 L1: call BtoD jmp L3 L2: mov ax,A call BtoD jmp L3 display1 proc mov ah , 02h ;回车换行 mov dl , 0ah int 21h mov ah , 02h mov dl , 0dh int 21h ret display1 endp display2 proc ;显示字符串 push ax ;保护现场 push dx ;保护入口参数 call display1 ;回车换行 pop dx mov ah , 09h ;显示提示字符串 int 21h pop ax ;恢复现场 ret display2 endp DtoB proc ;十进制装化成十六进制 push dx ;保护现场——程序中所使用到的寄存器 push si push bx push cx lea dx , inputdata ;输入十进制字符串 mov ah , 0ah int 21h mov si , 0 ;取字符串中字符的指针 mov ax , 0 ;累加结果 mov bx , 10 ;基数10 mov cl , inputdata+1;字符串长度送入cx,若为0,则直接退出,赋值result为0 mov ch , 0 jcxz exit again: mul bx ;ax*bx=dx:ax,这里输入为0~65535,乘积不会超过16位数据,dx必定为0 mov dl , inputdata[si+2] ;取输入的字符,转换为数值,累加到部分和 sub dl , 30h mov dh , 0 add ax , dx inc si loop again pop cx ;恢复现场——逆序出栈 pop bx pop si pop dx exit: ret DtoB endp BtoD proc ;十六进制转化成十进制数据 push cx push si push dx mov cx , 10 ;数制转换的基数 lea si , data1+4 ;si指针指向缓冲区末尾,依次减量,使余数倒序排列 again: mov dx , 0 ;除法转换,要使用32位被除数,dx为无符号数的0扩展,每次除法都要进行扩展 div cx ;除法后,ax为商,准备下次除法;

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档