微机原理实验报告-冒泡排序

上传人:汽*** 文档编号:511384418 上传时间:2023-09-17 格式:DOC 页数:11 大小:219.52KB
返回 下载 相关 举报
微机原理实验报告-冒泡排序_第1页
第1页 / 共11页
微机原理实验报告-冒泡排序_第2页
第2页 / 共11页
微机原理实验报告-冒泡排序_第3页
第3页 / 共11页
微机原理实验报告-冒泡排序_第4页
第4页 / 共11页
微机原理实验报告-冒泡排序_第5页
第5页 / 共11页
点击查看更多>>
资源描述

《微机原理实验报告-冒泡排序》由会员分享,可在线阅读,更多相关《微机原理实验报告-冒泡排序(11页珍藏版)》请在金锄头文库上搜索。

1、一、实验目的(1)学习汇编语言循环结构语句的特点,重点掌握冒泡排序的方法。(2)理解并掌握各种指令的功能,编写完整的汇编源程序。(3)进一步熟悉DEBUG的调试命令,运用DEBUG进行调试汇编语言程序。二、实验内容及要求(1)实验内容:从键盘输入五个有符号数,用冒泡排序法将其按从小到大的顺序排序。(2)实验要求:编制程序,对这组数进行排序并输出原数据及排序后的数据;利用DEBUG调试工具,用D0命令,查看排序前后内存数据的变化;去掉最大值和最小值,求出其余值的平均值,输出最大值、最小值和平均值;用压栈PUSH和出栈POP指令,将平均值按位逐个输出;将平均值转化为二进制串,并将这组二进制串输出;

2、所有数据输出前要用字符串的输出指令进行输出提示,所有数据结果能清晰显示。开始三、程序流程图(1)主程序:MAIN初始化键盘输入数据调用INPUT子程序显示输入错误输入是否正确 否 是显示原始数据调用OUTPUT子程序显示冒泡排序后的数据调用SORT子程序调用OUTPUT子程序显示最小值Min显示One子程序显示最大值Max调用One子程序显示其余数平均值Average调用One子程序显示平均值二进制串Binary调用One子程序结束(2)冒泡排序子程序: SORTCOUNT1 - 外循环次数COUNT2 - 内循环次数i - 数组下标进入初始化COUNT1=N-1COUNT2=COUNT1SI

3、=0AiAi+1 否 是Ai与Ai+1两数交换SI=SI+2COUNT2=COUNT2-1COUNT2=0? 否 是COUNT1=COUNT1-1COUNT2=0? 否 是返回四、程序清单NAME BUBBLE_SORTDATA SEGMENTARRAY DW 5 DUP(?) ;输入数据的存储单元COUNT DW 5 TWO DW 2FLAG1 DW 0 ;判断符号标志FLAG2 DB 0 ;判断首位是否为零的标志FAULT DW -1 ;判断出错标志CR DB 0DH,0AH,$STR1 DB Please input five numbers seperated with space a

4、nd finished with Enter:,$STR2 DB The original numbers:,$STR3 DB The sorted numbers:,$STR4 DB The Min:,$STR5 DB The Max:,$STR6 DB The Average:,$STR7 DB The binary system of the average :,$STR8 DB Input error!Please input again!$DATA ENDSCODE SEGMENTMAIN PROC FARASSUME CS:CODE,DS:DATA,ES:DATASTART: PU

5、SH DS AND AX,0 PUSH AX MOV AX,DATA MOV DS,AX LEA DX,STR1 MOV AH,09H ;9号DOS功能调用,提示输入数据 INT 21H CALL CRLF ;回车换行REIN: CALL INPUT ;调用INPUT子程序,输入原始数据 CMP AX,FAULT ;判断是否出错, JE REIN ;出错则重新输入 LEA DX,STR2 MOV AH,09H ;9号DOS功能调用,提示输出原始数据 INT 21H CALL OUTPUT ;调用OUTPUT子程序,输出原始数据 CALL SORT ;调用SORT子程序,进行冒泡排序 LEA D

6、X,STR3 MOV AH,09H ;9号DOS功能调用,提示输出排序后的数据 INT 21H CALL OUTPUT ;调用OUTPUT子程序,输出排序后的数据 AND SI,0 AND BX,0 MOV BX,ARRAYSI ;将最小值存入BX LEA DX,STR4 MOV AH,09H ;9号DOS功能调用,提示输出数据的最小值 INT 21H CALL ONE ;调用ONE子程序,输出最小值 CALL CRLF LEA DX,STR5 MOV AH,09H ;9号DOS功能调用,提示输出排序后的最大值 INT 21H MOV BX,ARRAYSI+8 ;将最大值存入BX CALL O

7、NE ;调用ONE子程序,输出最大值 CALL CRLF LEA DX,STR6 MOV AH,09H ;9号DOS功能调用,提示输出平均值 INT 21H AND DX,0 MOV AX,ARRAYSI+2 ;将去掉最大最小值的其余各数之和存入AX ADD AX,ARRAYSI+4 ADC AX,ARRAYSI+6 MOV CX,COUNT ;计数器CX=5 DEC CX ;CXCX-1 DEC CX DIV CX ;字除法,余数存入AX MOV BX,AX ;将余下各数的平均值存入BX CALL ONE ;调用ONE子程序,输出去掉最大最小值的其余数平均值 CALL CRLF LEA DX

8、,STR6 MOV AH,09H ;9号DOS功能调用,提示输出平均值的二进制串 MOV CX,16 ;16位二进制串,计数器初始值为16LL1: AND DX,0 DIV TWO PUSH DX LOOP LL1 MOV CX,16LL2: POP DX ADD DL,30H ;将DL中的数进行ASCII码转换 MOV AH,2 ;2号DOS功能调用,输出字符“0”或“1” INT 21H LOOP LL2 MOV AH,4CH INT 21H ;4C号功能调用,返回DOSMAIN ENDP;-子程序:CRLF功能: 回车和换行;-CRLF PROC LEA DX,CR MOV AH,09H INT 21H RETCRLF ENDP;-子程序:INPUT功能: 输入一组数据;-INPUT PROC

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > PPT模板库 > 总结/计划/报告

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号