emu8086实现两位数乘法运算
题目说明:从键盘上输入任意两个不大于2位数的正实数,计算其乘积,结果在屏幕上显示
一、准备材料
DOS功能调用表:https://blog.csdn.net/mybelief321/article/details/13168071
emu8086软件:https://emu8086-microprocessor-emulator.en.softonic.com/
ASCII码参考表:http://ascii.911cha.com/
二、asm代码
其中的注释详细解释了每一步代码的含义
由于算法本身的原因,输入的数字必须是两位数,例如:23,05,01,03,99……
data segment
num1 db "Enter Number 1: $"
num2 db "Enter Number 2: $"
resultstring db "Num1 * Num2 = Result: $"
result db 0,0,0,0,"$"
ends code segment
start:
mov ax, data
mov ds, ax
;将data数据放入data段 lea dx, num1
;将num1的有效地址放入dx
mov ah, 09h
;调用DOS的09H号功能,显示字符串,用来显示“Enter Number 1: ”
int 21h
;调用DOS mov ah, 01h
;调用DOS的01H号功能:键盘输入并回显。AL存入输入的字符
int 21h
;调用DOS
sub al, 30h
;减去30的原因:键盘键入“1”时,获得1的ASCII码为31,因此减去31,得到真实的数字1, 0~9同理
mov bl, al
;将输入的十位上的数字放入bl mov al, 0ah
mul bl
;十位上的数字×10 放入ax
mov bl, al
;由于个位数× 0ah 得到的数字总是小于等于两位的,所以AH必定为00H mov ah, 1h
int 21h
sub al,30h
;获得个位上的数字
add bl, al
;个位上的数字 + 十位上的数字×10 = Number 1
;此时bl 存入输入的第一个数字的真实大小 mov ah,2
mov dl,0ah
;调用DOS的02H号功能:显示输出。此时显示的是DL的内容:ASCII(10)为LF 换行
int 21h
;调用DOS
mov dl,0dh
;此时DL为ASCII(15)为CR 回车
int 21h
;调用DOS ;以下为重复输入数字的过程,不再赘述
lea dx, num2
mov ah, 9
int 21h mov ah, 1h
int 21h
sub al, 30h
mov dl, al mov al, 0ah
mul dl
mov dl, al mov ah, 1h
int 21h
sub al,30h
add dl, al
;此时dl内存入了Number 2 的真实大小 mov al, bl
mul dl
;此时ax内存入了两数乘积结果(Hex) mov bx, 0ah
mov cx, 4
mov si, 3
;si为什么等于3:从第3、2、1、0位开始处理result字段,将每一位结果分别存入个、十、百、千位上
; si: 0, 0, 0, 0, "$"
; 千 百 十 个
;位置 0, 1, 2, 3 getresult:
mov dx, 0000h
;将dx清空,用以以下步骤:
div bx
;ax中的乘积 ÷ 0ah , 商得数会在ax刷新 余数保存在dl
;因此dl中现在保存了第si位的数字
add dl, 030h
;转换为ASCII码,显示出字符类型的数字
mov byte ptr result+si, dl
sub si, 1
;si-=1,下一循环处理低一位的数字
loop getresult ;接下来输出提示语:Num1 × Num2 = ……
mov ah,2
mov dl,0ah ;输出换行
int 21h
mov dl,0dh ;输出回车
int 21h
lea dx, resultstring
mov ah, 9
int 21h
lea dx, result display:
mov ah, 9
int 21h mov ah, 4ch
mov al, 00h
;DOS 4CH号功能:带返回值结束程序,返回值为AL
int 21h
ends end start
三、技巧分享
1、程序捕获到的键盘输入,是按键所代表的ASCII 码,并非其字符本身,例如数字“1”的ASCII 码为31
2、
3、
4、
5、
emu8086实现两位数乘法运算的更多相关文章
- emu8086实现两位数加法运算
题目说明:给出一个公式,例如 "35 + 28 = ",输出计算结果 一.准备材料 DOS功能调用表:https://blog.csdn.net/mybelief321/artic ...
- SQL获取当前时间月份为两位数
--获取当前时间月份为两位数 )),) --获取当前时间上月月份为两位数 , )),)
- 需求:过滤下面这个网页里共723行 校对中里 行数为两位数的 行 并设置sz和rz在Windows和Linux之间发送和接收文件不用搭FTP
需求:过滤下面这个网页里共723行 校对中里 行数为两位数的 行 并设置sz和rz在Windows和Linux之间发送和接收文件不用搭FTP 需求:过滤下面这个网页里共723行 校对中里 行数为两位数 ...
- eclipse find 两位数
查找两位数
- Confusing Date Format UVALive 7711 给定mm-mm-mm格式的时间。年份(1900-1999)只给了后两位数,问有多少种合法的排列使时间正确。
/** 题目:Confusing Date Format UVALive 7711 链接:https://vjudge.net/contest/174844#problem/A 题意:给定mm-mm- ...
- 练习五十七:for循环 809??=800*?+9*?+1其中?代表的两位数,8*?的结果为两位数,9*?的结果为3位数。求?代表的两位数,及809??后的结果
题目:809??=800*?+9*?+1其中?代表的两位数,8*?的结果为两位数,9*?的结果为3位数.求?代表的两位数,及809??后的结果 注意:一定要看清楚题目哦,809??代表的是结果,?代表 ...
- 页面加载后累加,自加1&&判断数字是否为两位数
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 【JAVA习题二十九】809*??=8*??+9*??+1 其中??代表的两位数,8*??的结果为两位数,9*??的结果为3位数。求??代表的两位数,及809*??后的结果。
package erase; public class 八九与问好两位数的乘积和 { public static void main(String[] args) { int m,n;//m十位,n个 ...
- Java实现获取一个随机的两位数
import java.util.Random; //获取一个随机的 两位数public class getrandomdouble { public static void main(String[ ...
随机推荐
- Nginx的优化与防盗链
Nginx的优化与防盗链 1.隐藏版本号 2.修改用户与组 3.缓存时间 4.日志切割 5.连接超时 6.更改进程数 7.配置网页压缩 8.配置防盗链 9.fpm参数优化 1.隐藏版本号: 可以使用 ...
- Python接口自动化测试_悠悠
https://yuedu.baidu.com/ebook/585ab168302b3169a45177232f60ddccda38e695###
- Solution -「ARC 101D」「AT4353」Robots and Exits
\(\mathcal{Description}\) Link. 有 \(n\) 个小球,坐标为 \(x_{1..n}\):还有 \(m\) 个洞,坐标为 \(y_{1..m}\),保证上述坐标 ...
- Note -「线性规划」学习笔记
\(\mathcal{Definition}\) 线性规划(Linear Programming, LP)形式上是对如下问题的描述: \[\operatorname{maximize}~~~~z= ...
- Solution -「ARC 104F」Visibility Sequence
\(\mathcal{Description}\) Link. 给定 \(\{x_n\}\),对于满足 \(h_i\in[1,x_i]\) 的序列 \(\{h_n\}\),定义序列 \(\{p ...
- Python基础—编码(Day2)
一.字符编码 1.ASCII码:包含英文.数字.特殊字符,8位=1字节byte =1个字符,如: 0010 1010 ASCII码表里的字符总共有256个,前128个为常用的字符如运算符,后128个称 ...
- Java IO模型:BIO、NIO、AIO
Java IO模型:BIO.NIO.AIO 本来是打算直接学习网络框架Netty的,但是先补充了一下自己对Java 几种IO模型的学习和理解.分别是 BIO.NIO.AIO三种IO模型. IO模型的基 ...
- CobaltStrike逆向学习系列(11):自实现 Beacon 检测工具
这是[信安成长计划]的第 11 篇文章 关注微信公众号[信安成长计划] 0x00 目录 0x01 检测原理 0x02 检测方案 0x03 存在的问题 0x04 解决方案 0x05 示例代码 0x06 ...
- ubuntu改镜像源
https://blog.csdn.net/qq_28193019/article/details/89352824
- 详解 c# 克隆
克隆方法是原型设计模式中必须使用的方式,它将返回一个与当前对象数据一致的对象.正如其名,犹如一个模子雕刻而出.克隆类型分为两种:浅克隆.深克隆. 浅复制就是仅复制类中的值类型成员 深复制就是复制类中的 ...