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

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一、实验目的 1)学习汇编语言循环结构语句的特点,重点掌握冒泡排序的方法。 2)理解并掌握各种指令的功能,编写完整的汇编源程序。 3)进一步熟悉 DEBUG的调试命令,运用 DEBUG进行调试汇编语言程序。 二、实验内容及要求 1)实验内容:从键盘输入五个有符号数,用冒泡排序法将其按从小到大的顺序排序。 2)实验要求: ①编制程序,对这组数进行排序并输出原数据及排序后的数据; ②利用 DEBUG调试工具,用 D0 命令,查看排序前后内存数据的变化; ③去掉最大值和最小值,求出其余值的平均值,输出最大值、最小值和平均值; ④用压栈 PUSH和出栈 POP指令,将平均值按位逐个输出; ⑤将平均值转化为二进制串,并将这组二进制串输出; ⑥所有数据输出前要用字符串的输出指令进行输出提示, 所有数据结果能清晰显示。 三、程序流程图 (1)主程序 :MAIN 开始 初始化 键盘输入数据 调用 INPUT子程序 显示输入错误 输入是否正确 否 是 显示原始数据 调用 OUTPUT子程序 显示冒泡排序后的数据 调用 SORT子程序 调用 OUTPUT子程序 显示最小值 Min 显示 One子程序 显示最大值 Max 调用 One子程序 显示其余数平均值 Average 调用 One子程序 显示平均值二进制串 Binary 调用 One子程序 结束 (2)冒泡排序子程序 : SORT COUNT1---- 外循环次数 进入 COUNT2---- 内循环次数 初始化 COUNT1=N-1 COUNT2=COUNT1 SI=0 Ai ≥Ai+1 否 否 否 四、程序清单 NAME BUBBLE_SORT DATA SEGMENT  是 Ai 与 Ai+1 两数交换 SI=SI+2 COUNT2=COUNT2-1 COUNT2=0 是 COUNT1=COUNT1-1 COUNT2=0 是 返回 ARRAY DW 5 DUP() ; 输入数据的存储单元 COUNT DW 5 TWO DW 2 FLAG1 DW 0 ; 判断符号标志 FLAG2 DB 0 ; 判断首位是否为零的标志 FAULT DW -1 ; 判断出错标志 CR DB 0DH,0AH,$ STR1 DB Please input five numbers seperated 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 ENDS CODE SEGMENT MAIN PROC FAR ASSUME CS:CODE,DS:DATA,ES:DATA START: 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子程序,进行冒泡排序 LEA DX,STR3 MOV AH,09H ;9 号 DOS功能调用,提示输出排序后的数据 INT 21H CALL OUTPUT ; 调用 OUTPUT子程序,输出排序后的数据 AND SI,0 AND BX,0 MOV BX,ARRAY[SI] ; 将最小值存入 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,ARRAY[SI+8] ; 将最大值存入 BX CALL ONE ; 调用 ONE子程序,输出最大值 CALL CRLF LEA DX,STR6 MOV AH,09H ;9

文档评论(0)

152****0818 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档