微机原理实验报告-冒泡排序(共11页).docx
《微机原理实验报告-冒泡排序(共11页).docx》由会员分享,可在线阅读,更多相关《微机原理实验报告-冒泡排序(共11页).docx(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-1CO
3、UNT2=COUNT1SI=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
4、 with space and 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:
5、DATASTART: PUSH 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子程序
6、,进行冒泡排序 LEA DX,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 ;将最
7、大值存入BX CALL ONE ;调用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子程序,输出去掉最大最小值的其余数平均值 CAL
8、L CRLF LEA DX,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,
9、CR MOV AH,09H INT 21H RETCRLF ENDP;-子程序:INPUT功能: 输入一组数据;-INPUT PROC MOV CX,COUNT ;计数器CX=5 AND SI,0NEXT1: CALL DTB ;调用DTB子程序,将输入转换为二进制数 DEC CX ;CXCX-1 CMP DL,20H ;判断输入字符是否为空格符 JE STO CMP DL,0DH ;判断输入字符是否为换行符 JE EXIT2 CALL CRLF ERROR: LEA DX,STR8 MOV AH,09H ;9号DOS功能调用,提示输入不合法 INT 21H CALL CRLF MOV AX,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 微机 原理 实验 报告 冒泡 排序 11
限制150内