实验四_循环结构汇编语言程序设计实验报告.doc_第1页
实验四_循环结构汇编语言程序设计实验报告.doc_第2页
实验四_循环结构汇编语言程序设计实验报告.doc_第3页
实验四_循环结构汇编语言程序设计实验报告.doc_第4页
实验四_循环结构汇编语言程序设计实验报告.doc_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

循环结构汇编语言程序设计实验报告实验四 循环结构汇编语言程序设计一、实验目的 1、学习循环结构的汇编语言程序的设计和调试。2、学习通过直接对8086计算机的寄存器和内存的直接访问,编写更高效简洁的汇编程序。3、加深掌握计算机整体的工作过程。3、加深对排序算法的理解。二、实验任务编写程序求出数组A中(20个元素)的最大值和最小值(数组没有排序)。要求至少采用二种不同的排序算法来实现。( 快速排序,归并排序、堆排序、Shell排序、插入排序、冒泡排序、交换排序、选择排序、基数排序)三、实验内容为了更好地实现老师所布置的实验任务,我们根据情况选取以下两种方式实验。1、 利用冒泡排序的方式求解数组A中元素的最大值最小值。设计流程图如下所示:2、 利用选择排序的方式求得数组A中元素的序列。设计流程图如下所示:四、实验环境PC机: winXP/win7(32位)/win7(64位)+winxp 虚拟机汇编工具:Masm.exe+Link.exe。 五、实验步骤1)建立和生成的文件 (1)编写的源程序,源程序名为abc、扩展名为.asm(2)源程序经汇编程序Masm.exe汇编(翻译)后生成二进制目标程序,文件名为abc.obj(3)目标程序需要经Link.exe连接生成可执行程序,文件名为abc.exe 2)汇编环境最基本的汇编环境只需要两个文件:Masm.exe和Link.exe。将这两个文件拷入到已经建好的文件夹(例如 huibian)中,并将文件夹huibian放在硬盘根目录C :下3)上机步骤进入DOS窗口中执行。4)调试程序进入DEBUG后,调试程序5)调试成功后重新汇编、连接并生成可执行代码6)执行程序,并对运行结果截图。利用冒泡排序求得数组A中元素的最大值最小值的实验结果如下图所示:(说明:输入数据为:13,0,59,900,587,1,657,234,34,48)利用选择排序对数组A中元素排序得到的序列得实验结果如下图所示:(说明:输入数据为13,0,59,900,587,1,657,234,34,48)六、实验心得通过本次循环结构汇编语言程序设计的实验,我初步了解了汇编语言的基本语法,利用汇编语言的循环结构实现了对于数组A中元素的排序以及求得元素中的最大值最小值。另外,在实验过程中,我也了解到了,我们要时刻细心严谨,认真做好每一步,避免出现低级错误。七、汇编语言代码1、利用冒泡排序实现求最大值最小值的代码data segment mes1 db the max:$ mes2 db the min:$ a dw 13,0,59,900,587,1,657,234,34,48data ends code segment main proc far assume cs:code,ds:data start: push ds sub ax,ax push ax mov ax,data mov ds,ax ;以下是起泡排序核心代码 mov cx,10dec cx loop1: mov di,cx mov bx,0 loop2: mov ax,abx cmp abx+2,ax jge cotinue xchg ax,abx+2 mov abx,ax cotinue: add bx,2 loop loop2 mov cx,di loop loop1 mov dx,offset mes1 mov ah,09h int 21h mov bx,a18 call bini ;转换为十进制的子程序 mov dx,offset mes2 mov ah,09h int 21h mov bx,a0 call bini ret main endp bini proc near mov cx,10000d call bin mov cx,1000d call bin mov cx,100d call bin mov cx,10d call bin mov cx,1d call bin ret bini endp bin proc near mov ax,bx mov dx,0 div cx mov bx,dx mov dl,al add dl,30h mov ah,02h int 21h ret bin endp crlf proc near mov dl,0ah mov ah,02h int 21h mov dl,0dh mov ah,02h int 21 ret crlf endp code ends end start2、利用选择排序实现排序的代码SAVEREG macro push ax push bx push cx push dx push si push di endm RESAVEREG macro pop di pop si pop dx pop cx pop bx pop ax endm ;* data segment arr dw 13,20,59,900,587,1,657,234,34,48 n dw 18 m dw 10 data ends ;* code segment ;- main proc far assume cs:code, ds:data start: push ds sub ax, ax push ax mov ax, data mov ds, ax ;- ;sort ;- ;si,di index ;ax temp mov si, 0 mov di, 0 loop1: cmp si, n jge OUTER1 ;init loop2 mov ax, si add ax, 2 mov di, ax loop2: cmp di, n jg OUTER2 mov ax, arrsi cmp ax, arrdi jle DO_NOTHING xchg ax, arrdi mov arrsi, ax DO_NOTHING: add di, 2 jmp loop2 OUTER2: add si, 2 jmp loop1 OUTER1: mov cx, m mov di, 0 PRINT_LOOP: mov ax, arrdi mov dx, 0 call print_dec add di, 2 loop PRINT_LOOP ;read key from the keyboard mov ah, 0 int 16h ret ;- ;get_oct function ;must pass ax, dx print_dec proc near SAVEREG mov cx, 0 mov bx, 10 GET_NUM_LOOP: div bx push dx mov dx, 0 inc cx cmp ax, 0 jne GET_NUM_LOOP PRINT: pop dx add dx, 30h mov ah, 02h int 21h loop PRINT

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论