预处理阶乘和阶乘逆元_计算数字的阶乘| 8086微处理器

预处理阶乘和阶乘逆元

Problem statement:

问题陈述:

Write an assembly language program for calculating the factorial of a number using 8086 microprocessor.

编写一个汇编语言程序,以使用8086微处理器来计算数字的阶乘。

Assumptions:

假设:

  • Starting address of program: 0400

    程序起始地址:0400

  • Input memory location: 0500

    输入存储器位置:0500

  • Output memory location: 0600 and 0601

    输出存储器位置:0600和0601

Point to be noted:

需要注意的地方:

If the Given Number is a 16-bit number, the AX register is automatically used as the second parameter and the product is stored in the DX:AX register pair. This means that the DX register holds the high part and the AX register holds the low part of a 32-bit number.

如果给定数字是16位数字,则AX寄存器将自动用作第二个参数,并且乘积存储在DX:AX寄存器对中。 这意味着DX寄存器保持32位数字的高位,而AX寄存器保持32位数字的低位。

Algorithm:

算法:

  1. Input the Number whose factorial is to be find and Store that Number in CX Register (Condition for LOOP Instruction)

    输入要查找其阶乘的编号,并将该编号存储在CX寄存器中(LOOP指令的条件)

  2. Insert 0001 in AX(Condition for MUL Instruction) and 0000 in DX

    在AX(MUL指令的条件)中插入0001,在DX中插入0000

  3. Multiply CX with AX until CX become Zero(0) using LOOP Instruction

    使用LOOP指令将CX与AX相乘,直到CX变为零(0)

  4. Copy the content of AX to memory location 0600

    将AX的内容复制到内存位置0600

  5. Copy the content of DX to memory location 0601

    将DX的内容复制到内存位置0601

  6. Stop Execution

    停止执行

Program:

程序:

ADDRESSMNEMONICSCOMMENTS
0400MOV CX, [0500]CX ← [0500]
0404MOV AX, 0001AX ← 0001
0407MOV DX, 0000DX ← 0000
040AMUL CXDX:AX ← AX * CX
040CLOOP 040AGo To [040A] till CX->00
0410MOV [0600], AX[0600]←AX
0414MOV [0601], DX[0601]←DX
0418HLTStop Execution
地址 记忆 注释
0400 MOV CX,[0500] CX←[0500]
0404 MOV斧,0001 斧←0001
0407 MOV DX,0000 DX←0000
040A MUL CX DX:AX←AX * CX
040C 环040A 转到[040A]直到CX-> 00
0410 MOV [0600],AX [0600]←AX
0414 MOV [0601],DX [0601]←DX
0418 HLT 停止执行

Explanation:

说明:

  1. MOV CX, [0500] loads 0500 Memory location content to CX Register

    MOV CX ,[0500]将0500内存位置内容加载到CX寄存器

  2. MOV AX, 0001 loads AX register with 0001

    MOV AX ,0001将0001装入AX寄存器

  3. MOV DX, 0000 loads DX register with 0000

    MOV DX ,0000将0000装入DX寄存器

  4. MUL CX multiply AX with CX and store result in DX:AX pair

    MUL CX将AX与CX相乘并将结果存储在DX:AX对中

  5. LOOP 040A runs loop till CX not equal to Zero

    LOOP 040A循环运行,直到CX不等于零

  6. MOV [0600], AX store AX register content to memory location 0600

    MOV [0600] ,AX将AX寄存器内容存储到内存位置0600

  7. MOV [0601], DX store DX register content to memory location 0601

    MOV [0601] ,DX将DX寄存器内容存储到存储器位置0601

  8. HLT stops the execution of program

    HLT停止执行程序

翻译自: https://www.includehelp.com/embedded-system/calculate-the-factorial-of-a-number.aspx

预处理阶乘和阶乘逆元

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/545661.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GB/T 17710-1999 PHP生成校验码

校验码算法描述如下:详细:http://wenku.baidu.com/link?urlCDvNJ1sLYOPzbbxjEy5R-oME95RlfTCUU5-I5M0bqUt0I32b0Xd0EKmI-HiFQHhY8OcB6ERTml7pUwXFseLl8GGvkuc7w0V2sFDxi2H0XGC本例子以16位编号为例子,用PHP予以实现,代码如下&…

Linux——线程使用及互斥量

线程的基本操作 概念 线程是程序中的一个执行路线。每个程序当中至少有一个线程。 程序在执行的过程中是逐条执行的,按照代码的逻辑一次向下执行,所以无法同时完成两条指令,故而引进了线程,举个很简单的例子,如果同时…

UNDO Tablespace

UNDO表空间用于存放UNDO数据,当执行DML操作(insert、update、delete)的时候,oracle会将这些操作的旧数据写入到UNDO段。UNDO数据也称为回滚数据,用于确保数据的一致性。作用包括:1、回退事务2、读一致性3、…

第 4-2 课:反射和动态代理 + 面试题

反射 反射机制是 Java 语言提供的一种基础功能,赋予程序在运行时自省(introspect)的能力。简单来说就是通过反射,可以在运行期间获取、检测和调用对象的属性和方法。 反射的使用场景 在现实中反射的使用场景有很多,比如以下几个。 使用场景一:编程工具 IDEA 或 Eclip…

出现奇数次的数字_查找出现奇数次的数字

出现奇数次的数字Problem statement 问题陈述 Given an array of positive numbers where all the numbers occur even number of times except only one number which occurs an odd number of times. We need to find the special number (number occurring an odd number o…

linux——常用指令

指令功能ls列出当前目录下所有子目录和文件pwd显示当前目录的路径cd 目录名进入该目录cd …返回上一级目录touch 文件名创建一个文件mkdir 文件夹名创建一个文件夹rmdir 文件名与mkdir相对,删除一个文件夹,但必须拥有对当前目录进行操作的权限rm -r删除目…

js中div显示和隐藏钮为什么页面总是跳一下到最上面

<div class"menu_left"> <ul > <li id"t1" style"background-image:url(images/t2.gif);" > <a href"#" id"first" οnclick"infoList(first);" >中心动态</a><…

ORA-00911:无效字符 错误及解决

今天写了一局sql语句&#xff0c;用来向Oracle数据库插入一条数据。我是这样写的……String sql "insert into userinfo(usermail,usernickname,userpassword)values(?,?,?);";结果出现ORA-00911:无效字符&#xff0c;解决方法是&#xff1a;………去掉sql语句最…

第 5-2 课:线程池——ThreadPoolExecutor + 面试题

线程池介绍 线程池(Thread Pool):把一个或多个线程通过统一的方式进行调度和重复使用的技术,避免了因为线程过多而带来使用上的开销。 为什么要使用线程池? 可重复使用已有线程,避免对象创建、消亡和过度切换的性能开销。避免创建大量同类线程所导致的资源过度竞争和内…

创建动画

1.动画&#xff08;头部-开始动画&#xff09; [UIView beginAnimations:nil context:nil];2.设置动画的执行时间 [UIView setAnimationDuration:1.0];3.向上移动// CGPoint tempCenter _btn.center; CGRect tempFrame _btn.frame;tempFrame.origin.y - 50;_btn.frame tempF…

安卓安装kali linux之Termux

本文讲述如何在手机上安装kali linux,我本想安装其他版本的linux,但不知是什么原因安装到一半就卡住&#xff0c;最终安装kali成功了&#xff0c;但也只是安装了kali的壳子&#xff0c;在inux上的操作都可以实现&#xff0c;只是工具并没有安装&#xff0c;后期可以自主安装工具…

常用的作业调度算法应用练习

单道环境下四个作业&#xff0c;它们进入系统的时间如下&#xff1a;作业进入时间估计运行时间&#xff08;分钟&#xff09;JOB18:00120JOB28:5050JOB39:0010JOB49:5020(1)给出FCFS , SJF&#xff0c;HRN下的作业执行次序(2)给出FCFS , SJF, HRN下的作业平均周转时间和带权平均…

第 5-1 课:线程与死锁 + 面试题

线程介绍 线程(Thread)是程序运行的执行单元,依托于进程存在。一个进程中可以包含多个线程,多线程可以共享一块内存空间和一组系统资源,因此线程之间的切换更加节省资源、更加轻量化,因而也被称为轻量级的进程。 什么是进程 进程(Processes)是程序的一次动态执行,是…

检查列表中的所有元素在Python中是否相同

Here, we are implementing a python program to check whether all elements of a list are the same or not? 在这里&#xff0c;我们正在实现一个python程序来检查列表中的所有元素是否相同&#xff1f; We can use [1:] and [:-1] to compare all the elements in the g…

调用百度人脸识别API进行人脸对比 C语言

百度人脸识别api使用是免费的&#xff0c;有人脸对比、人脸搜索、人脸检测与属性分析三个功能&#xff0c;本文写的是人脸对比。这里给出百度人脸对比api的技术文档&#xff0c;请点击网址https://cloud.baidu.com/doc/FACE/s/Lk37c1tpf 另外需要注册百度智能云&#xff0c;获取…

(自连接)SQL面试题-0608

一个简单的表TABLE 有100条以上的信息&#xff0c;其中包括&#xff1a;产品 颜色 数量产品1 红色 123产品1 蓝色 126产品2 蓝色 103产品2 红色 NULL产品2 红色…

SQL Server 2005 常用数据类型详解

1. 字符串数据类型char此数据类型可存储1~8000个定长字符串&#xff0c;字符串长度在创建时指定&#xff1b;如未指定&#xff0c;默认为char(1)。每个字符占用1byte存储空间。nchar此数据类型可存储1~4000个定长Unicode字符串&#xff0c;字符串长度在创建时指定&#xff1b;如…

第 5-4 课:ThreadLocal 详解 + 面试题

什么是 ThreadLocal? ThreadLocal 诞生于 JDK 1.2,用于解决多线程间的数据隔离问题。也就是说 ThreadLocal 会为每一个线程创建一个单独的变量副本。 ThreadLocal 有什么用? ThreadLocal 最典型的使用场景有两个: ThreadLocal 可以用来管理 Session,因为每个人的信息都…

Java LinkedList公共对象peek()方法(带示例)

LinkedList公共对象peek()方法 (LinkedList public Object peek() method) This method is available in package java.util.LinkedList.peek(). 软件包java.util.LinkedList.peek()中提供了此方法。 This method is used to retrieve the head element of the linked list wit…

舵机驱动

舵机的驱动是以PWM信号的占空比来控制的&#xff0c;该PWM信号的周期位20ms&#xff0c;宽度在0.5ms——2.5ms之间&#xff0c;驱使舵机转动角在0——180度之间&#xff0c;一些常用角度对应脉宽如下表&#xff1a; 舵机转动角脉宽00.5 ms451 ms901.5 ms1352 ms1802.5 ms 在实…